精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JavaScript:打破所有規(guī)則

開發(fā) 前端 開發(fā)工具
北京時(shí)間今天凌晨,來自Twitter的前端工程師Angus Crol,在柏林舉辦的JSConf會(huì)議上,進(jìn)行了題為"Break all the Rulez"的演講,主要講了一些我們通常認(rèn)為是錯(cuò)誤的不該使用的東西,其實(shí)是有用的.本文最下面有演講用的slides.遠(yuǎn)在美國的JavaScript之父看了slides也說:我同意其中大部分觀點(diǎn)(看來還是有問題?).

北京時(shí)間今天凌晨,來自Twitter的前端工程師Angus Crol,在柏林舉辦的JSConf會(huì)議上,進(jìn)行了題為"Break all the Rulez"的演講,主要講了一些我們通常認(rèn)為是錯(cuò)誤的不該使用的東西,其實(shí)是有用的.本文最下面有演講用的slides.遠(yuǎn)在美國的JavaScript之父看了slides也說:我同意其中大部分觀點(diǎn)(看來還是有問題?).

下面我把要點(diǎn)簡單翻譯一下,不做擴(kuò)展解釋.

with語句

為什么不去使用它?

1.意外的運(yùn)行結(jié)果,可能隱式創(chuàng)建全局變量

2.閉包作用域解析過多消耗

3.后期編譯

有人說,ES5的嚴(yán)格模式可以防止隱式創(chuàng)建全局變量(不用var),這樣能減少with的一個(gè)問題.但是...

嚴(yán)格模式也不能使用with啊.

為什么說它是有用的?

1.構(gòu)建瀏覽器開發(fā)者工具

 
  1. //Chrome Developer Tools  
  2. IS._evaluateOn =  
  3.   function(evalFunction, obj, expression) {  
  4.     IS._ensureCommandLineAPIInstalled();  
  5.     expression =  
  6.       "with (window._inspectorCommandLineAPI) {\  
  7.         with (window) { " + expression + " } }";  
  8.     return evalFunction.call(obj, expression);  

2.模擬塊級(jí)作用域

 
 
 

 

 

  1. //是的,還是這個(gè)老掉牙的問題  
  2. var addHandlers = function(nodes) {  
  3.   for (var i = 0; i < nodes.length; i++) {  
  4.     nodes[i].onclick =  
  5.       function(e) {alert(i);}  
  6.   }  
  7. }; 
  1. //你可以通過在外面包一個(gè)函數(shù)來解決  
  2. var addHandlers = function(nodes) {  
  3.   for (var i = 0; i < nodes.length; i++) {  
  4.     nodes[i].onclick = function(i) {  
  5.       return function(e) {alert(i);};  
  6.     }(i);  
  7.   }  
  8. }; 
  1. //或者使用'with'來模擬塊級(jí)作用域  
  2. var addHandlers = function(nodes) {  
  3.   for (var i = 0; i < nodes.length; i++) {  
  4.     with ({i:i}) {  
  5.       nodes[i].onclick =  
  6.         function(e) {alert(i);}  
  7.     }  
  8.   }  
  9. }; 

#p#

eval語句

為什么不去使用它?

1.代碼注入

2.無法進(jìn)行閉包優(yōu)化

3.后期編譯

為什么說它是有用的?

1. JSON.parse不可用的時(shí)候

有人在Stack Overflow上說:

“JavaScript的eval是不安全的,使用json.org上的JSON解析器來解析JSON”

還有人說:

“不要使用eval來解析JSON!用道格拉斯寫的json2.js!”

可是:

 
  1. // From JSON2.jsif (/^[\],:{}\s]*$/  .test(text.replace(/*regEx*/, '@')  .replace(/*regEx*/, ']')  .replace(/*regEx*/, ''))) {  j = eval('(' + text + ')');} 

2.瀏覽器的JavaScript控制臺(tái)都是用eval實(shí)現(xiàn)的

在Webkit控制臺(tái)或JSBin中執(zhí)行下面的代碼

 
  1. >(function () {    console.log(String(arguments.callee.caller))})()function eval() {    [native code]} 

John Resig說過:

“eval和with是被輕視的,被誤用的,被大部分JavaScript程序員公然譴責(zé)的,但如果能正確使用的話,可以用它們寫出一些奇妙的,無法用其他功能實(shí)現(xiàn)的代碼”

Function構(gòu)造函數(shù)

為什么說它是有用的?

1.代碼運(yùn)行在可預(yù)見的作用域內(nèi)

2.只能動(dòng)態(tài)創(chuàng)建全局變量

3.不存在閉包優(yōu)化的問題

用在了什么地方?

1. jQuery的parseJSON

 
  1. // jQuery parseJSON   
  2.  
  3. // Logic borrowed from http://json.org/json2.js  
  4. if (rvalidchars.test(data.replace(rvalidescape,"@")  
  5.   .replace( rvalidtokens,"]")  
  6.   .replace( rvalidbraces,""))) {  
  7.  
  8.   return ( new Function( "return " + data ) )();  

2.Underscore.js的字符串內(nèi)插

 
  1. //from _.template  
  2.  
  3. // If a variable is not specified,  
  4. // place data values in local scope.  
  5. if (!settings.variable)   
  6.   source = 'with(obj||{}){\n' + source + '}\n';  
  7.  
  8. //..  
  9.  
  10. var render = new Function(  
  11.   settings.variable || 'obj''_', source); 

#p#

==運(yùn)算符

為什么不去使用它?

1.強(qiáng)制將兩邊的操作數(shù)轉(zhuǎn)換為相同類型

為什么說它是有用的?

1.強(qiáng)制將兩邊的操作數(shù)轉(zhuǎn)換為相同類型

2.undefined == null

 
  1. //這樣寫是不是很麻煩  
  2. if ((x === null) || (x === undefined))  
  3.  
  4. //完全可以下面這樣寫  
  5. if (x == null)  

3.當(dāng)兩邊的操作數(shù)類型明顯相同時(shí)使用

 
  1. typeof thing == "function";   //typeof運(yùn)算符肯定返回字符串  
  2. myArray.length == 2;          //length屬性肯定返回?cái)?shù)字  
  3. myString.indexOf('x') == 0;   //indeOf方法肯定返回?cái)?shù)字 

真值不一定==true,假值不一定==false

  1. if ("potato") {  
  2.   "potato" == true;  //false  
  3. }  
 

Array構(gòu)造函數(shù)

為什么不去使用它?

1.new Array()也是evil的?JSLint也推薦使用[].

為什么說它是有用的?

  1. //From prototype.js extension of   
  2. //String.prototype  
  3. function times(count) {  
  4.   return count < 1 ?  
  5.     '' : new Array(count + 1).join(this);  
  6. }  
  7. 'me'.times(10); //"memememememememememe" 
 

其他

不要擴(kuò)展原生的原型對(duì)象
(es 5 shims都這么干)
在for/in遍歷時(shí)總要使用hasOwnProperty
(在沒有擴(kuò)展對(duì)象原型的前提下沒有必要這么做)
把所有的var語句放在頂部
(for語句還是放在初始化表達(dá)式中好)
要在調(diào)用函數(shù)之前先聲明函數(shù)
(在優(yōu)先考慮實(shí)現(xiàn)細(xì)節(jié)時(shí)使用)
不要使用逗號(hào)運(yùn)算符
(在使用多個(gè)表達(dá)式時(shí)的時(shí)候可以使用)
使用parseInt時(shí)總要把第二個(gè)參數(shù)指定為10
(除非字符串以‘0’或‘x’開頭,否則沒必要)

#p#

譯者注

上面說了這么多,我自己也想到一個(gè)被誤解的東西,那就是escape.網(wǎng)上有不少人說:"不要使用escape".

為什么說它是有用的?

1.escape轉(zhuǎn)義的字符更多,有時(shí)候需要轉(zhuǎn)義后兩個(gè)函數(shù)不轉(zhuǎn)義的字符.

ASCII char escape() encodeURI() encodeURIComponent()
! %21 ! !
# %23 # %23
$ %24 $ %24
& %26 & %26
' %27 ' '
( %28 ( (
) %29 ) )
+ + + %2B
, %2C , %2C
/ / / %2F
: %3A : %3A
; %3B ; %3B
= %3D = %3D
? %3F ? %3F
@ @ @ %40
~ %7E ~ ~

2.將字符串轉(zhuǎn)換為UTF8編碼,通常用在base64的時(shí)候.

escape相當(dāng)于是在utf16編碼的字符串上轉(zhuǎn)義,encodeURIComponent相當(dāng)于是先把utf16的字符串轉(zhuǎn)換成utf8編碼后再escape.

encodeURIComponent(str) === escape(UTF16ToUTF8(str))

可以推導(dǎo)出UTF16ToUTF8(str) === unescape( encodeURIComponent( str )

然后就能用在base64編碼的時(shí)候,比網(wǎng)上看到的那些簡單多了吧.注意btoa和atob有兼容問題.

  1. function base64Encode(str) {  
  2.     return btoa(unescape(encodeURIComponent(str)));  
  3. }  
  4.  
  5. function base64Decode(str) {  
  6.     return decodeURIComponent(escape(atob(str)));  
責(zé)任編輯:林師授 來源: 博客園
相關(guān)推薦

2009-04-17 13:14:48

數(shù)據(jù)庫Apache關(guān)系模型

2023-10-04 07:52:37

2015-01-06 17:06:01

創(chuàng)新App

2016-11-11 14:12:28

電商雙十一潛規(guī)則

2011-03-16 16:54:10

iptables 清空linux

2020-02-19 14:02:49

JavaScriptthis前端

2023-10-07 10:27:29

2009-03-13 09:39:34

JavaScript函數(shù)調(diào)用規(guī)則

2015-10-08 15:36:24

JavaScript規(guī)則

2024-04-26 08:27:15

JavaScriptCSSHTML元素

2021-07-02 09:12:39

數(shù)字化

2022-07-07 09:19:24

JavaScript代碼樣式規(guī)則

2021-01-14 07:52:24

JavaScript回調(diào)函數(shù)

2017-09-05 16:17:35

JavaScript運(yùn)算轉(zhuǎn)換

2017-09-13 10:58:51

JavaScript轉(zhuǎn)換規(guī)則

2019-12-18 14:39:44

云計(jì)算云安全數(shù)據(jù)

2012-11-14 09:20:00

大數(shù)據(jù)PrismHadoop

2009-04-17 10:09:49

非關(guān)系數(shù)據(jù)庫SimpleDB

2020-06-23 14:51:13

JavaScript字符字符串

2023-11-14 16:57:10

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

91亚洲国产高清| 久久r热视频| 国产精品一区一区| 8050国产精品久久久久久| 亚洲精品国产一区黑色丝袜 | 欧美插天视频在线播放| 精品1卡二卡三卡四卡老狼| 伊人久久综合一区二区| 中文字幕一区二区三区视频| 国产亚洲欧美一区二区| 在线免费观看日韩视频| 极品日韩av| 色哟哟网站入口亚洲精品| 最新中文字幕日本| 久久天堂影院| 日韩欧美在线免费观看| 99久久99久久精品| 成人18在线| av午夜一区麻豆| 91香蕉亚洲精品| 国产精品视频123| 欧美日本亚洲韩国国产| 在线视频欧美日韩精品| 日批在线观看视频| 精品国产三区在线| 欧美午夜在线观看| 青青草国产精品视频| 麻豆最新免费在线视频| 久久精品视频一区| 国产尤物91| 精品人妻一区二区三区换脸明星| 久久裸体视频| 久久人人97超碰精品888| 国产精品嫩草影院俄罗斯| 欧美禁忌电影网| 亚洲国产一区二区三区在线观看 | 成人永久aaa| 成人黄色在线免费| 中文字幕一区二区三区人妻四季| 欧美一级二区| 97视频免费在线观看| 欧美人妻精品一区二区免费看| 日本不卡二三区| 亚洲欧洲一区二区三区在线观看| 视频免费在线观看| 91综合久久爱com| 欧美一级二级在线观看| 伊人网在线综合| 国产麻豆一区| 欧美日本一区二区| 狠狠躁狠狠躁视频专区| 四虎影视4hu4虎成人| 一本到高清视频免费精品| 可以在线看的av网站| 波多野结衣在线观看| 亚洲国产中文字幕| 国产玉足脚交久久欧美| gogo久久| 欧美日韩一区二区在线播放| 国产在线青青草| 中文字幕av一区二区三区佐山爱| 色综合天天性综合| 欧美日韩大尺度| 日韩色淫视频| 91精品国产综合久久福利软件| 91插插插影院| 视频精品一区| 精品国产99国产精品| 久久久午夜精品福利内容| 黄色免费大全亚洲| 亚洲人a成www在线影院| 99精品欧美一区二区| 午夜激情久久| 欧美日韩国产va另类| 日韩成人一区二区三区| 美女久久一区| 91午夜理伦私人影院| 欧美熟女一区二区| 久久婷婷国产综合精品青草| 日韩精品久久一区二区三区| 亚洲欧美视频一区二区| 一区二区激情视频| 成人中文字幕在线播放| 僵尸再翻生在线观看免费国语| 黑人巨大精品欧美一区二区一视频 | 欧美视频在线播放| 一本之道在线视频| 欧美精品密入口播放| 国产一区av在线| 日本老熟俱乐部h0930| 影音先锋亚洲电影| 国产99久久久欧美黑人| 一区二区三区午夜| 成人国产电影网| 亚洲精品国产精品久久| 性欧美1819sex性高清大胸| 福利微拍一区二区| 992tv人人草| 亚洲区小说区图片区qvod| 精品激情国产视频| 性无码专区无码| 精久久久久久久久久久| 精品国产一区二区三区麻豆免费观看完整版| 免费在线高清av| 一区二区三区欧美视频| 久久久久免费精品| y111111国产精品久久久| 亚洲一级黄色av| 日韩激情在线播放| 久88久久88久久久| 玛丽玛丽电影原版免费观看1977 | 黑人玩弄人妻一区二区三区| 国产日产精品一区二区三区四区的观看方式| 久久夜色精品国产欧美乱| 丁香六月婷婷综合| 丰满白嫩尤物一区二区| 亚洲精品在线免费看| 国产伦久视频在线观看| 91精品久久久久久久99蜜桃| 免费看黄色的视频| 亚洲精品乱码| 99免费在线观看视频| 成人在线免费看| 狠狠做深爱婷婷久久综合一区| 亚洲AV成人精品| 三上亚洲一区二区| 日韩免费黄色av| 特黄视频在线观看| 亚洲国产一二三| 杨幂一区二区国产精品| 色综合五月天| 国产精品第一页在线| 污污网站在线免费观看| 亚洲综合一二区| 久久无码人妻一区二区三区| 99精品国产一区二区三区| 国产精品中文在线| 国产在线观看免费网站| 狠狠久久五月精品中文字幕| 亚洲精品乱码久久| 伊人成人在线视频| 99三级在线| 主播国产精品| 日韩女优电影在线观看| 欧美爱爱免费视频| 精久久久久久久久久久| 中文字幕一区综合| 亚洲国产天堂| 久久久精品在线| 国产乱色精品成人免费视频| 亚洲婷婷在线视频| 色啦啦av综合| 91不卡在线观看| 91亚洲永久免费精品| 最新黄网在线观看| 精品国产三级a在线观看| 国产一级性生活| 99久久精品免费看国产免费软件| 久久综合久久久久| 成人h动漫精品一区二区器材| 欧美精品18videosex性欧美| 乱精品一区字幕二区| 亚洲成人你懂的| 制服丝袜第二页| 日韩国产高清在线| 中文字幕中文字幕一区三区| 国产亚洲观看| 国产69精品久久久久99| 亚洲三级黄色片| 欧美在线播放高清精品| 午夜精品久久久久99蜜桃最新版| 国产综合成人久久大片91| 黄色三级中文字幕| 婷婷成人综合| 国产欧美va欧美va香蕉在| 高h视频在线观看| 欧美精品一区二| 无码人妻精品一区二区三区9厂 | 九九热国产在线| caoporn国产精品| 欧美性猛交久久久乱大交小说 | 草草草视频在线观看| 国产伦精品一区二区三区在线播放 | 99国产精品久| 天天干天天爽天天射| 欧美日韩国产欧| 欧美不卡三区| 激情综合五月| 国产97在线亚洲| 天堂av资源在线观看| 亚洲免费视频网站| jizz中国少妇| 色综合天天视频在线观看| 天堂网中文在线观看| 懂色av一区二区夜夜嗨| www.日本xxxx| 亚洲久色影视| 免费在线观看污污视频| 日韩丝袜视频| 91探花福利精品国产自产在线| 黄色软件视频在线观看| 久久人人爽人人爽爽久久| 日韩av成人| 日韩限制级电影在线观看| 日韩在线播放中文字幕| 一区二区三区四区在线免费观看 | 亚洲欧美激情另类| 欧美怡红院视频| 亚洲精品国产精品乱码| 亚洲女爱视频在线| 国产成人福利在线| eeuss国产一区二区三区| 一区二区三区四区毛片| 免费日韩av片| 国产毛片久久久久久国产毛片| 日韩理论在线| 欧美不卡福利| 卡通动漫精品一区二区三区| 96pao国产成视频永久免费| 欧美舌奴丨vk视频| 久久人人爽人人爽人人片av高请| 国产在线1区| 神马久久桃色视频| 免费国产在线观看| 日韩国产精品亚洲а∨天堂免| 亚洲国产综合网| 69堂成人精品免费视频| 中文字幕在线日亚洲9| 欧美午夜无遮挡| 国产精品黄色大片| 亚洲午夜免费电影| avove在线播放| 最新国产の精品合集bt伙计| 综合 欧美 亚洲日本| 久久精品亚洲精品国产欧美| 性欧美丰满熟妇xxxx性仙踪林| 成人短视频下载| 四虎精品一区二区| 岛国一区二区三区| 国产伦理在线观看| 国产精品一卡二| 四川一级毛毛片| 成人一区二区视频| 国产精品91av| 成人午夜视频网站| 男男一级淫片免费播放| 成人爱爱电影网址| 亚洲精品乱码久久久久久蜜桃欧美| 国产成人免费xxxxxxxx| 国产在线观看免费播放| 成人在线综合网站| 先锋资源av在线| 久久亚洲免费视频| 精品人妻中文无码av在线| 欧美国产一区二区| 日本裸体美女视频| 亚洲麻豆国产自偷在线| 亚洲色婷婷一区二区三区| 夜夜嗨av一区二区三区| 日本熟妇毛茸茸丰满| 高跟丝袜一区二区三区| 国产精品久久久久久久久夜色| 在线观看日韩毛片| 艳妇乳肉豪妇荡乳av| 91精品国产综合久久久久| www.亚洲黄色| 亚洲精品动漫100p| 精品av中文字幕在线毛片| 中文字幕亚洲综合久久| 免费高清在线观看| 欧美激情第99页| 日本不卡网站| 国产日韩在线视频| 亚洲专区**| 欧美激情视频一区二区三区| 成人综合久久| 日本一本中文字幕| 日韩高清不卡一区二区| 巨乳女教师的诱惑| 91一区二区三区在线观看| 99久久99久久精品免费看小说.| 亚洲丝袜另类动漫二区| 久热这里只有精品在线| 91久久精品一区二区三| 国产一区二区波多野结衣| 精品国产乱码久久久久久牛牛 | 日本女优爱爱视频| 看电视剧不卡顿的网站| 亚洲熟妇一区二区| 欧美激情在线一区二区| 久久久久99精品成人片试看| 欧美午夜性色大片在线观看| 国产三级小视频| 亚洲精品永久免费| 黄色成人影院| 欧美有码在线视频| 4438五月综合| 久久久久久一区| 欧美精品国产一区| 992kp快乐看片永久免费网址| 国产风韵犹存在线视精品| 美女脱光内衣内裤| 亚洲综合在线视频| 97精品人妻一区二区三区香蕉| 日韩精品高清在线观看| 成人看片免费| 国产精品激情av电影在线观看| 91精品尤物| 中文字幕免费高| 日韩有码一区二区三区| 亚洲欧美高清在线| 中文字幕在线观看一区二区| 国产成人在线观看网站| 欧美一级日韩免费不卡| 91啦中文在线| 奇米一区二区三区四区久久| 日韩中文一区二区| 性刺激综合网| 久久亚洲色图| 人妻激情偷乱频一区二区三区 | 麻豆映画在线观看| 日韩一区精品视频| 真人bbbbbbbbb毛片| 一区二区三区精品在线观看| 国产乱码一区二区| 色妞在线综合亚洲欧美| 成人免费看视频网站| 国产乱码精品一区二区三区日韩精品| **女人18毛片一区二区| 奇米视频7777| 国产日韩精品一区二区三区| av大片免费观看| 日韩电影大全免费观看2023年上| 亚洲性图自拍| 亚洲va久久久噜噜噜久久天堂| 清纯唯美综合亚洲| 成人黄色一区二区| 久久久久久久久久久久久久久99 | 国产直播在线| 国产日韩一区二区三区| 黄色欧美成人| 老熟女高潮一区二区三区| 亚洲精品日产精品乱码不卡| 国产精品爽爽久久| www.xxxx精品| 懂色av色香蕉一区二区蜜桃| 最新不卡av| 国内外成人在线| 91视频综合网| 6080yy午夜一二三区久久| 免费黄色网页在线观看| 成人网在线观看| 91精品一区二区三区综合在线爱| 捷克做爰xxxⅹ性视频| 亚洲女性喷水在线观看一区| www国产一区| 久久久久亚洲精品| 欧美成人一区在线观看| 黄在线观看网站| 国产午夜亚洲精品不卡| 在线免费看av片| 久久精品视频一| 在线观看视频一区二区三区| 我的公把我弄高潮了视频| 91社区在线播放| 欧美性猛交xxxx乱大交hd| 中文字幕亚洲综合久久筱田步美| 欧美高清免费| 日韩国产小视频| 91色视频在线| 国产精品久免费的黄网站| 国产亚洲精品久久久久久777| 亚洲久草在线| 男女猛烈激情xx00免费视频| 国产亚洲美州欧州综合国| 亚洲最大成人av| 欧美激情中文网| 欧美**vk| 色欲无码人妻久久精品| 偷窥少妇高潮呻吟av久久免费| wwwxxx在线观看| 91九色在线观看| 久久精品九九| 高h视频免费观看| 精品香蕉一区二区三区| 91麻豆精品国产91久久久更新资源速度超快| 麻豆视频传媒入口| 国产精品免费精品一区| 亚洲黄色www网站| 成人日韩av| av免费观看大全| 中文字幕亚洲在| 亚洲av毛片成人精品| 91欧美精品成人综合在线观看| 亚洲茄子视频| 日韩欧美国产成人精品免费| 日韩国产高清视频在线| 久久天堂久久| mm1313亚洲国产精品无码试看| 亚洲精品高清视频在线观看|