国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JQuery最佳實踐之精妙的自定義事件

2019-11-21 00:18:22
字體:
來源:轉載
供稿:網友
恰好偶最近負責的一個可視化編輯器的開發,其中有些地方便應用了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>

在線演示
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 夏邑县| 高密市| 余江县| 原平市| 海丰县| 达尔| 磴口县| 普兰店市| 隆林| 延川县| 泽州县| 玉溪市| 房山区| 安丘市| 太仓市| 渝北区| 徐汇区| 双城市| 师宗县| 炎陵县| 南漳县| 尚义县| 神农架林区| 武胜县| 辽宁省| 沐川县| 怀柔区| 曲沃县| 封丘县| 九江市| 浦北县| 永靖县| 镇巴县| 栖霞市| 瓦房店市| 武定县| 黑龙江省| 金坛市| 大关县| 时尚| 蛟河市|