文章标签 ‘JavaScript脚本’
3 条评论[原创]简单的模板替换机制-jquery实现了局部
今天帮同事修改一个Tip提示的效果 提示中 需要用到当前元素的几个属性,就帮忙改了改之前的demo
这里是一个局部实现 可以参考
查看临时Demo
实际应用的案例:http://www.iamued.com/demo/simpletip/template/
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>一个jquery的小模板机制-我是UED</title>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<script language="JavaScript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
</head>
<body>
<a id="test" price="110" name="iphone" onmouseover="test();" href="#">这是一个A元素 有2个属性 鼠标放上来看看</a>
临时Demo的部分代码:
<script type="text/javascript">
function test(){
var testString="价格为{price}元,我是{name}"
alert(testString.replace(/{([^{}]+)}/g,function(word){
var _attr=word.replace(/({|})+/g,"");
return $("#test").attr(_attr);
}));
}
</script>
</body>
</html>
查看临时Demo
实际应用的案例:http://www.iamued.com/demo/simpletip/template/
2 条评论[转]js中匿名函数的N种写法
在java中有private属性,强大的功能js不能实现就矮人一截,匿名函数,发扬广大
匿名函数没有实际名字,也没有指针,怎么执行滴?
其实大家可以看看小括号的意义就应该可以理解。小括号有返回值,也就是小括号内的函数或者表达式的返回值,所以说小括号内的function返回值等于小括号的返回值,不难理解 (function(){})()可以将没有名字的函数执行了把…
关于匿名函数写法,很发散~
//最常见的用法:
(function() {
alert('water');
})();
//当然也可以带参数:
(function(o) {
alert(o);
})('water');
//想用匿名函数的链式调用?很简单:
(function(o) {
alert(o);
return arguments.callee;
})('water')('down');
//常见的匿名函数都知道了,看看不常见的:
~(function(){
alert('water');
})();
//写法有点酷~
void function(){
alert('water');
}();
//据说效率最高~
+function(){
alert('water');
}();
-function(){
alert('water');
}();
~function(){
alert('water');
}();
!function(){
alert('water');
}();
(function(){
alert('water');
}());
//有点强制执行的味道~
Sorry :) 刚才忘记把转载地址附上了
转自:
http://blog.163.com/water_down/blog/static/1702765902010869124093/
1 条评论太NB了:Google Docs Ctrl + C 技术浅析
从玉伯那里转来的,Goole非常NB
用 google docs 打开 pdf 文件,选中文本:

表面上没有任何有趣的地方。但仔细一看,会发现选区的颜色是浅蓝色,而不是默认蓝。第一直觉是是有什么特殊的 CSS 属性,立马 firebug:

不看不知道,一看真蹊跷。selection-highlight 是选区,选区下面是一张图片 page-image!
于是立刻发现一个非常牛逼的特性:Ctrl + C 可以复制图片中的文字!
google 太强悍了,好在前端代码都是开源的,下面简单分析下。
首先数据在哪呢,这个比较容易找到,在 firebug 里有一个请求返回的数据如下:
<?xml version="1.0" encoding="UTF-8"?> <pdf2xml> <meta name="Creator" content="Adobe Acrobat 8.1 Combine Files"/> <meta name="Producer" content="Adobe Acrobat 8.1"/> <meta name="CreationDate" content="20100316080708-04'00'"/> <page t="0" l="0" w="612" h="773"> <text l="188" t="754" w="237" h="11" p="188,24,214,15,232,37,271, 7,280,39,322,7,330,11,344,24,370,23,395,20,418,7"> Please post comments or corrections to the Author Online forum at</text> ...
有了这份数据,就可以根据选区得到对应的文本。
接下来的问题是,如何将文本放到剪贴板里?第一反应是用 flash 实现,但感觉 google 不会这么做。禁用掉 flash 插件后,功能正常,这说明是用 js 实现的。
通过 Profile 工具 + Fiddler + 肉眼识别 + 运气,终于定位到了关键代码:
n.am = function(a) {
if (! (!this.k.Ca && Mr(this, a))) {
ac && this.lf.focus();
this.lf.select();
Nr(this, a)
}
};
只要注释掉上面的代码,Ctrl + C 复制功能就无效。focus 和 select 为我们提供了进一步线索,在 HTML 里,发现了秘密:

到此真相大白:当用户按下 Ctrl + C 时,js 会注入事件,首先根据坐标从数据里取出对应文本,然后将文本赋值给 textarea, 并将其激活和选中。这样,就和用户选中 textarea 的内容,再按下 Ctrl + C 的效果是一样了。
强悍的 google, 技术创新无处不在!
注意:利用 textarea 只能复制纯文本,如果想复制富文本,可以借鉴 google docs 编辑 Word 文档时的处理方式:采用 iframe 充当临时容器,有兴趣的可以进一步研究。
发现这个秘密后,最近在疯狂搞编辑的牛人承玉(欢迎搞编辑器的其他牛人加盟)立刻想到了各大站长们非常喜爱的功能:附带警告信息的禁止copy. 据说,能成功复制的,都不是“人”。
我的尝试是:点击按钮,复制指定文本到 Clipboard 里。应用场景是点击按钮复制证件号码等。尝试代码大家可以看上面 demo 页面源码中的注释。事件可以正常模拟并分发出去,但复制操作惨兮兮地失败了。感觉原因在于浏览器安全限制,对于触发的异步 Ctrl + C, 浏览器会限制其功能。
Google 的产品里有很多秘密,真诱人,创意无限!
没有评论判断 iframe 是否加载完成的完美方法
今天正好需要判断iframe加载完成 正好找到怿飞同学的这篇文章 方法很完美
var iframe = document.createElement("iframe");
iframe.src = "http://www.planabc.net";
if (!/*@cc_on!@*/0) { //if not IE
iframe.onload = function(){
alert("Local iframe is now loaded.");
};
} else {
iframe.onreadystatechange = function(){
if (iframe.readyState == "complete"){
alert("Local iframe is now loaded.");
}
};
}
document.body.appendChild(iframe);
最近, Nicholas C. Zakas 文章《Iframes, onload, and document.domain》的评论中 Christopher 提供了一个新的判断方法(很完美):
var iframe = document.createElement("iframe");
iframe.src = "http://www.planabc.net";
if (iframe.attachEvent){
iframe.attachEvent("onload", function(){
alert("Local iframe is now loaded.");
});
} else {
iframe.onload = function(){
alert("Local iframe is now loaded.");
};
}
document.body.appendChild(iframe);
几点补充说明:
- IE 支持 iframe 的 onload 事件,不过是隐形的,需要通过 attachEvent 来注册。
- 第二种方法比第一种方法更完美,因为 readystatechange 事件相对于 load 事件有一些潜在的问题。

