給自定義對(duì)象加上自定義事件的支持的教程
更新時(shí)間:2008年03月13日 21:19:27 作者:
自從我寫了幾個(gè)還可以拿出手的東東之后,自我感覺牛B了許多,還有不少同志圍著我,稱我為高手,虛容心大大的得到了滿足。這些是后話,暫且不表。。。
我一般是不看別人寫的代碼的,為啥?累!而且這位同志給的還是經(jīng)過壓縮的!汗。。。考我是不是?還有,這位同志也不給個(gè)示例的代碼,只說是代碼沒有問題。我努力的試著去“破解”,但是腦細(xì)胞死的太快了!在我沒有變成白癡之前,我毅然決定,不在往下看下去。不就是給自定的對(duì)象加入自定事件的支持嗎?我寫個(gè)示例吧,就算是教程了,如果看不懂,我也沒有辦法了!我不會(huì)傻到給你寫好代碼,讓你拿去賣錢的!
好了,下面是我寫的代碼,注意看了:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
示例中,自定義了一個(gè):JCEvent,c1,c2,c3都是這它的實(shí)例。
每個(gè)實(shí)例都有一個(gè)oOutline,我一般用它來做為對(duì)象的容器。pParent是用來指示自定義對(duì)象在哪里顯示的,也就相當(dāng)于占位符吧,如果不指定,就是document.body。
示例中,我定義了三個(gè)自定事件:onCreate,onChangeSkin,onClick
onCreate 在 create方法里觸發(fā)。
onChangeSkin在setSkin方法里觸發(fā)。
onClick在oOutline.onclick里觸發(fā)。
調(diào)用順序:
由于onCreate是在create方法里調(diào)用的,所以c1.onCreate要在c1.create()之前聲明。
事件的參數(shù),見:
this.setSkin = function(pSkin){
var oldSkin = oOutline.className;
oOutline.className = pSkin;
if(typeof this.onChangeSkin == "function")
this.onChangeSkin(oldSkin,pSkin);
}
this.onChangeSkin(oldSkin,pSkin);
這樣,你就可以在每個(gè)實(shí)例里運(yùn)用oldSkin和newSkin了。
如:
c1.onChangeSkin = function(pOld,pNew){
alert("onChangeSkin事件\n設(shè)置c1的皮膚:\n新皮膚:" + pNew + "\n舊皮膚:" + pOld);
}
另外,示例中:
$.$css = function(pKey,pValue,p){
var obj = p ? $.$(p) : this;
obj.style[pKey] = pValue;
obj.$css = $.$css;
return obj;
}
這一段,寫成Object.prototype.$css = function(...)是絕對(duì)不成功的,至于為什么,就不是這里的討論范圍。
沒話可說了,就留空白吧,看不懂的同志,在補(bǔ)補(bǔ)你們的javascript知識(shí)。
說點(diǎn)題外話:不要老是整jQuery,prototype,json等。
好了,下面是我寫的代碼,注意看了:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
示例中,自定義了一個(gè):JCEvent,c1,c2,c3都是這它的實(shí)例。
每個(gè)實(shí)例都有一個(gè)oOutline,我一般用它來做為對(duì)象的容器。pParent是用來指示自定義對(duì)象在哪里顯示的,也就相當(dāng)于占位符吧,如果不指定,就是document.body。
示例中,我定義了三個(gè)自定事件:onCreate,onChangeSkin,onClick
onCreate 在 create方法里觸發(fā)。
onChangeSkin在setSkin方法里觸發(fā)。
onClick在oOutline.onclick里觸發(fā)。
調(diào)用順序:
由于onCreate是在create方法里調(diào)用的,所以c1.onCreate要在c1.create()之前聲明。
事件的參數(shù),見:
this.setSkin = function(pSkin){
var oldSkin = oOutline.className;
oOutline.className = pSkin;
if(typeof this.onChangeSkin == "function")
this.onChangeSkin(oldSkin,pSkin);
}
this.onChangeSkin(oldSkin,pSkin);
這樣,你就可以在每個(gè)實(shí)例里運(yùn)用oldSkin和newSkin了。
如:
c1.onChangeSkin = function(pOld,pNew){
alert("onChangeSkin事件\n設(shè)置c1的皮膚:\n新皮膚:" + pNew + "\n舊皮膚:" + pOld);
}
另外,示例中:
$.$css = function(pKey,pValue,p){
var obj = p ? $.$(p) : this;
obj.style[pKey] = pValue;
obj.$css = $.$css;
return obj;
}
這一段,寫成Object.prototype.$css = function(...)是絕對(duì)不成功的,至于為什么,就不是這里的討論范圍。
沒話可說了,就留空白吧,看不懂的同志,在補(bǔ)補(bǔ)你們的javascript知識(shí)。
說點(diǎn)題外話:不要老是整jQuery,prototype,json等。
相關(guān)文章
使用layui日期控件laydate對(duì)開始和結(jié)束時(shí)間進(jìn)行聯(lián)動(dòng)控制的方法
今天小編就為大家分享一篇使用layui日期控件laydate對(duì)開始和結(jié)束時(shí)間進(jìn)行聯(lián)動(dòng)控制的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09JavaScript函數(shù)、方法、對(duì)象代碼
函數(shù)定義可以嵌套在其他函數(shù)中,常用作子函數(shù)。但不能出現(xiàn)在循環(huán)或條件語句中。2008-10-10javascript產(chǎn)生隨機(jī)數(shù)方法匯總
這篇文章主要介紹了javascript產(chǎn)生隨機(jī)數(shù)方法匯總的相關(guān)資料,需要的朋友可以參考下2016-01-01JS實(shí)現(xiàn)簡單的天數(shù)計(jì)算器完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)簡單的天數(shù)計(jì)算器,結(jié)合完整實(shí)例形式分析了javascript針對(duì)日期的獲取及天數(shù)運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2017-04-04JS async 函數(shù)的含義和用法實(shí)例總結(jié)
這篇文章主要介紹了JS async 函數(shù)的含義和用法,結(jié)合實(shí)例形式總結(jié)分析了JS async 函數(shù)的基本功能、含義、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04淺談利用JavaScript進(jìn)行的DDoS攻擊原理與防御
這篇文章主要介紹了淺談利用JavaScript進(jìn)行的DDoS攻擊原理與防御,以及介紹了相關(guān)的中間人攻擊原理,需要的朋友可以參考下2015-06-06js實(shí)現(xiàn)數(shù)字從零慢慢增加到指定數(shù)字示例
今天小編就為大家分享一篇js實(shí)現(xiàn)數(shù)字從零慢慢增加到指定數(shù)字示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11