恰好偶最近負責的一個可視化編輯器的開發,其中有些地方便應用了JQuery的自定義事件,而且達到了很好的效果-精簡代碼的同時充分利用了OO的原則。
本文以我實際應用開發過程中遇到的一個例子進一步說明“什麼時候用JQuery的自定義事件以及怎麼用”,希望可以拋磚引玉,同時權且當是回復同學們的郵件了。
Demo-Ingenious JQuery custom event
JQuery最佳實踐-精妙的自定義事件
問題:一個復選框X,你如何便捷地觸發它的click事件的處理邏輯,但是又不改變它當前的選中狀態?
答案:用自定義事件處理函數封裝復選框click事件的處理邏輯!然後觸發該自定義事件。
以下應用場景你曾經遇到過麼?
需求:某個容器A,用戶可以設置它的4條邊框的有無以及邊框色?“邊框的有無”和“顏色的變化”需要聯動,
就是說改變邊框的時候獲取當前設定的顏色,改變顏色的時候獲取當前設定的邊框,並及時反映到容器A上。
注:本例子邊框顏色統一設置,分別設置的例子大家可以去寫下~
核心代碼:
代碼如下:
<div id="demo">
<div class="acts">
<label for="txtCpk"></label>邊框設置:<input type="text" size="10" id="txtCpk" name="color"/>
<input type="checkbox" name="bd" value="top"/><span>上</span>
<input type="checkbox" name="bd" value="right"/><span>右</span>
<input type="checkbox" name="bd" value="bottom"/><span>下</span>
<input type="checkbox" name="bd" value="left"/><span>左</span>
</div>
<textarea id="A" cols="100" rows="29"></textarea>
</div>
</body>
<script id="js" type="text/javascript">
//<![CDATA[
//目標容器A
var $a=$("#A");
//拾色器
var $txtColor=$("#txtCpk").ColorPicker({
onChange:function(hsb,hex,rgb){
$txtColor.val("#"+hex).css("backgroundColor","#"+hex);
//聯動邊框-觸發自定義事件"evtClick",避免改變復選框的狀態
//這裡可不能直接用$bd.trigger("click")噢;
//$bd.trigger("click");
$bd.trigger("evtClick");
}
});
//邊框及自定義事件的應用
var $bd=$("#demo input[type='checkbox']").bind("evtClick",function(evt){
var c=this.checked?"2px solid "+$txtColor.val():"none";
$a.css("border-"+this.value,c);
}).click(function(evt){
$(this).trigger("evtClick");
});
//show the js
$(document).ready(function(){
$a.val($("#js").html());
});
//]]>
</script>
在線演示