移動端 h5 開發相關內容總結——JavaScript 篇
來自: http://web.jobbole.com/84941/
1.改變頁面標題的內容
有時候我們開發 h5頁面的時候需要動態的去更新title 的名字,這個時候使用
JavaScript
document.titile='修改后的名字';
document.titile='修改后的名字';</div>
就可以解決我們的問題。
或者使用
JavaScript
//當前firefox對 title 參數不支持
history.pushstate(state,title,url);
//當前firefox對 title 參數不支持 history.pushstate(state,title,url);</div>
這種方法不僅能夠修改 title 而且能夠修改 url 的值,并且將這些信息存儲到瀏覽器的歷史堆棧中,當用戶使用返回按鈕的時候能夠得到更加好的體驗。當我們在做一個無刷新更新頁面數據的時候,可以使用這種方法來記錄頁面的狀態,使得頁面能夠回退。
2.日志記錄同步發送請求
有這樣的一個場景:
在做電商類的產品的時候,我們要對每個產品的點擊數進行統計(其實就是出發一個 ajax 請求)。PC端的交互大多數是點擊商品后新開頁面。這個時候 ajax 是 同步發送 或者 異步發送 對統計沒有影響。
但是嵌套在客戶端中,長長是在當前 tab 中跳頁。如果我們仍舊使用異步的 ajax 請求,有請求會被阻斷,統計結果不準確。
3.JavaScript 中 this 相關
這部分內容之前也是看過很多次,但是都不能夠理解深層次的含義。后來看的多了,也就理解了。
JavaScript
var ab = {
'a': 1,
'b': 2,
'c': 3,
abc:function(){
// 對象的方法中,this是綁定的當前對象
var that=this;
console.log('abc');
var aaa=function(){
//that指向的是當前對象
console.log(that.a);
//函數中this的值綁定的是全局的window對象
console.log(this);
};
aaa();
}
};
console.log('---------');
ab.abc();</pre>
var ab = {
'a': 1,
'b': 2,
'c': 3,
abc:function(){
// 對象的方法中,this是綁定的當前對象
var that=this;
console.log('abc');
var aaa=function(){
//that指向的是當前對象
console.log(that.a);
//函數中this的值綁定的是全局的window對象
console.log(this);
};
aaa();
}
};
console.log('---------');
ab.abc();
</div>
以上代碼瀏覽器中輸出結果如下:
JavaScript
var BBB=function(){
var a=0;
this.b=1;
return this;
}
var bb= new BBB();</pre>
var BBB=function(){
var a=0;
this.b=1;
return this;
}
var bb= new BBB();
</div>
在瀏覽器中輸入一下的內容查看輸出:
我們對代碼做一下修改,如下:
JavaScript
var BBB=function(){
var a=0;
this.b=1;
}
var bb= new BBB();</pre>
var BBB=function(){
var a=0;
this.b=1;
}
var bb= new BBB();
</div>
與之上相同的輸入,查看一下輸出是什么
由上可知 new 操作符的執行過程:
- 一個新對象被創建。它繼承自 BBB.prototype 。
- 構造函數 BBB 被執行。執行的時候,相應的傳參會被傳入,同時上下文 this 會被指定為這個新實例。 new BBB 等同于 new BBB() , 只能用在不傳遞任何參數的情況。
- 如果構造函數返回了一個“對象”,那么這個對象會取代整個new出來的結果。如果構造函數沒有返回對象,那么new出來的結果為步驟1創建的對象。
一般情況下構造函數不返回任何值,不過用戶如果想覆蓋這個返回值,可以自己選擇返回一個普通對象來覆蓋。當然,返回數組也會覆蓋,因為數組也是對象。
4.JavaScript 中閉包相關
定義在閉包中的函數可以“記憶”它創建時候的環境。
JavaScript
var test=function(string){
return function(){
console.log(string);
}
};
var tt=test();
tt();
var test=function(string){
return function(){
console.log(string);
}
};
var tt=test();
tt();
</div>
JavaScript
//li列表點擊每一行 顯示當前的行數
var add_li_event=function(node){
var helper=function(i){
return function(e){
alert(i);
}
};
for (var i = 0, len =node.length; i < len; i++) {
node[i].onclick=helper(i);
}
};</pre>
//li列表點擊每一行 顯示當前的行數
var add_li_event=function(node){
var helper=function(i){
return function(e){
alert(i);
}
};
for (var i = 0, len =node.length; i < len; i++) {
node[i].onclick=helper(i);
}
};
</div>
5.銷毀事件綁定
我自己在寫 js 的事件綁定的時候也經歷了一個過程,剛開始的時候 onclick , bind , live , delegate , on 這樣一個過程。
之所以會有這樣的需求就是因為我們頁面上的 DOM 是動態更新。比如說,某塊內容是點擊頁面上的內容顯示出來,然后在這塊新出現的內容上使用 click 肯定是滿足不了需求的。
live 和 delegate 屬于較早版本的事件委托(代理事件)的寫法。最新版本的 jquery 都是使用 on 來做代理事件。效率上比 live 和 delegate 更高。
live 是將事件綁定到當前的 document ,如果文檔元素嵌套太深,在冒泡的過程中影響性能。
而 delegate 和 on 的區別就是
JavaScript
jQueryObject.delegate( selector , events [, data ], handler )
//或者
jQueryObject.delegate( selector, eventsMap )
jQueryObject.delegate( selector , events [, data ], handler )
//或者
jQueryObject.delegate( selector, eventsMap )
</div>
JavaScript
jQueryObject.on( events [, selector ] [, data ], handler )
//或者
jQueryObject.on( eventsMap [, selector ] [, data ] )
jQueryObject.on( events [, selector ] [, data ], handler )
//或者
jQueryObject.on( eventsMap [, selector ] [, data ] )
</div>
由此可知,使用 on 的話,子代元素的選擇器是可選的。但是 delegate 的選擇器是必須的。 on 比 delegate 更加的靈活。
很多時候我們都是只聲明事件綁定,而不管事件的銷毀。但是在編寫前端插件的時候,我們需要提供事件銷毀的方法,提供給插件使用者調用。這樣做的好處就是使,使用者對插件更加可控,釋放內存,提供頁面的性能。
JavaScript
var that={};
$('.event_dom').on('click','.childK_dom',function(){});
$(window).on('scroll',scrollEvent);
var scrollEvent=function(){};
//事件銷毀
that.desrory=function(){
$('.event_dom').off();
//window 方法的銷毀必須使用事件名稱和回調函數,主要是 window 上可能綁定這系統自定義的事件和回掉
$(window).off('scroll',scrollEvent);
};
var that={};
$('.event_dom').on('click','.childK_dom',function(){});
$(window).on('scroll',scrollEvent);
var scrollEvent=function(){};
//事件銷毀
that.desrory=function(){
$('.event_dom').off();
//window 方法的銷毀必須使用事件名稱和回調函數,主要是 window 上可能綁定這系統自定義的事件和回掉
$(window).off('scroll',scrollEvent);
};
</div>
如果您覺得不錯,請訪問 github( 點我 ) 地址給我一顆星。謝謝啦!
</div>
本文由用戶 fmqg9864 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!
sesese色