分类目录归档:程序相关

C,Python,环境配置等

如何判断浏览器的javascript版本

如何判断浏览器的javascript版本

话说最近在研究某著名跟踪系统,在其给用户的实施代码中有一段判断浏览器Javascript版本的代码引起了我的注意,于是问了下google如何判断浏览器的javascript版本,他老人家说将所要执行的代码放在如< script language="JavaScript1.2" >所示嵌套下。但是当问到检测javascript版本时,得到如下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
var JS_ver  = [];
(Number.prototype.toFixed)?JS_ver.push("1.5"):false;
([].indexOf && [].forEach)?JS_ver.push("1.6"):false;
((function(){try {[a,b] = [0,1];return true;}catch(ex) {return false;}})())?JS_ver.push("1.7"):false;
([].reduce && [].reduceRight && JSON)?JS_ver.push("1.8"):false;
("".trimLeft)?JS_ver.push("1.8.1"):false;
JS_ver.supports = function()
{
if (arguments[0])
 
return (!!~this.join().indexOf(arguments[0] +",") +",");
else
 
return (this[this.length-1]);
}
alert("Latest Javascript version supported: "+ JS_ver.supports());
alert("Support for version 1.7 : "+ JS_ver.supports("1.7"));

这个脚本,既能通过检测特征来检测JavaScript版本,还能检查特定的Javascript版本所支持的特性。

得到了结果,我们还是看下此系统是如何检测javascript版本的吧,于是将其代码抽取出来(抽取过程相当纠结),得到如下所示代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<script type="text/javascript">
var n = navigator;
var u = n.userAgent;
 
var apn = n.appName;
var v = n.appVersion;
var ie = v.indexOf('MSIE ')
if(ie > 0){
   apv = parseInt(i = v.substring(ie + 5));
   if(apv > 3) {
       apv = parseFloat(i);
   }
}else{
   apv = parseFloat(v);
}
 
var isie = (apn == 'Microsoft Internet Explorer');
var ismac = (u.indexOf('Mac') >= 0);
 
var javascriptVersion = "1.0";
 
if(String && String.prototype){
   javascriptVersion = '1.1';
 
   if(javascriptVersion.match){
       javascriptVersion = '1.2';
 
       var tm = new Date;
       if(tm.setUTCDate){
           javascriptVersion = '1.3';
 
           if(isie && ismac && apv >= 5) javascriptVersion = '1.4';
 
           var pn = 0;
           if(pn.toPrecision){
               javascriptVersion = '1.5';
 
               a = new Array;
               if(a.forEach){
                   javascriptVersion = '1.6';
 
                   i = 0;
                   o = new Object;
                   tcf = new Function('o','var e,i=0;try{i=new Iterator(o)}catch(e){}return i');
                   i = tcf(o);
                   if(i && i.next) {
                       javascriptVersion = '1.7';
                   }
               }
           }
       }
   }
}
alert(javascriptVersion);
</script>

代码实现原理:根据不同版本的javascript对于一些特定函数的支持不同从而判断其版本所在。其中仅对1.4版本有一个特殊处理。

–EOF–

Python核心编程读书笔记:第4章,Python对象

第四章学习笔记
【4.1 python对象】
1、Python使用对象模型来存储数据。构造任何类型的值都是一个对象。
2、所有的python对象都拥有三个特性:身份,类型和值;这三个特性在对象创建的进修就被赋值了,除了值以外,其它两个都是只读的。但是某些类的类型也是可以改变的。
3、Python使用句点(.)标记法来访问属性

【4.3 其他内建类型】
1、通过调用type()函数你能够得到特定对象的类型信息
2、当使用Python扩展的切片语法时,就会创建切片对象
3、省略对象用于扩展切片语法中,起记号作用
4、xrange()函数是range()的兄弟版本,用于需要节省内存使用或range()无法完成的超大数据集场合

【4.5 标准类型操作符】
1、Python中多个比较操作可以在同一行进行,求值顺序为从左到右

1
3 < 4 < 7(3 < 4) and (4 < 7)相同

这说明其本质上是多个隐式的and连接起来的多个表达式

2、比较操作是针对对象的值进行的。
3、foo1 = foo2 = 4.3 创建一个4.3的数字对象,然后将这个对象的引用赋值给foo1和foo2,foo1和foo2指向同一个对象
4、Python是通过传递引用来处理对象
5、Python提供了is 和is not 操作符来测试两个变量是否指向同一个对象 如: a is b 等价于 id(a) == id(b)
6、整型和字符串对象是不可变对象,所以Python会很高效的缓存它们,但是在没有任何引用指向它时,这个字符串所占的空间会被回收

【4.6 标准类型内建函数】
1、type()接受一个对象作为参数,并返回它的类型,它的返回值是一个类型对象
2、cmp()用于比较两个对象obj1和obj2。如果是用户自定义对象,cmp()会调用访类的特殊方法__cmp__()。
3、str()和repr()和反引号操作符(“)可以方便地以字符串的方式获取对象的内容、类型、数值属性等信息。
repr()和“做提完全一样的事情,它们返回一个对象的“官方”的字符串,绝大多数情况下可以eval()重新得到该对象,而str()致力于生成一个对象的可读性好的字符串表示 。
4、Python不支持方法或函数重载
5、布尔比较总是返回True或False
6、所有的内建类型都是类,在这基础上,所有的所谓内建转换函数都成了工厂函数,虽然它们看上去有点像函数,实质上他们是类。当调用它们时,实际上是生成了该类型的一个实例,就像工厂生产货物一样。

【4.8 标准类型的分类】
1、字符串是一个自我包含的文字类型
2、以存储模型为标准的类型分类,标量/原子类型(数值,字符串)和容器类型(列表,元组、字典)
3、以更新模型为标准的类型分类,可变类型(列表、字典)和不可变类型(数字,字符串,元组)
4、以访问模型为标准的类型分类,直接访问(数字),顺序访问(字符串,列表,元组)和映射访问(字典)

【4.9 不支持的类型】
1、Python的整型实现等同于C语言的长整型
2、Python的浮点类型实际上是C语言的双精度浮点类型

在Facebook中使用FBML对特定内容进行评论,显示和隐藏like按钮的的方法

在Facebook中使用FBML对特定内容进行评论,显示和隐藏like按钮的的方法

某日,在facebook中需要对特定的内容进行评论,于是在FBML的文档中一顿狂搜,找到了传说中的 fb:comments 标签,看其DEMO,和我相像中的一样,当我把相关代码按照自己的想法贴到后台中FBML输入框中后,预览发现,纠结了,like按钮没有显示。当时,在那个当时,代码如下:

1
2
3
4
 
<fb:comments xid="138518389499724_comment_box2"  numposts="3"  width="350">
 
</fb:comments>

在纠结查找了一堆英文文档后发现没有什么解决方案,在官方的说明中只有隐藏like按钮的方法。

在某个偶然细致查找中,发现有属性没有设置,于是将各个属性都有试一次,结果发现当没有returnurl属性时,是没有like按钮的,

于时有了隐藏和显示like按钮的方法一:

通过设置returnurl来隐藏和显示like按钮

另外,如果不设置returnurl属性,则默认为当前页面地址

在发现了此方法后,却从其论坛中找到相同的解答,真相请猛击:http://forum.developers.facebook.net/viewtopic.php?pid=249815

上面有说到官方说明中有隐藏like按钮的方法,有兴趣的童鞋请猛击http://forum.developers.facebook.net/viewtopic.php?pid=238518

–EOF–