第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

jQuery應(yīng)用load()方法后js失效的問題分析與解決

標(biāo)簽:
JQuery

load()方法算是最简单的ajax了,非常方便,不过也有一些难以理解的地方。

比如不久前我出现了这样一个问题:

我的代码高亮是用pretty,它的特点是不破坏源代码,用js动态使代码着色,在载入正文后使用prettyPrint()函数使代码高亮生效。

我在另一个页面使用jQuery中的load()方法载入此页面的正文,但是代码区的高亮消失了,也就是说js代码未运行。这是可以理解的,因为load()方法并未运行原网页,而是将其当做数据传输,js根本未启动。

但是我在后面又加上prettyPrint()也依然没效果,再查看源代码才发现一个重要的问题:load()方法并未改变源代码,根本看不到我们load过来的正文内容。

我又使用find().is()来查找代码区的<pre>标签也显示没有。一段不存在的内容,应用prettyPrint()当然没效果了。

那么,load过来的内容到底去哪儿了呢?它真的不存在于任何地方吗?

不是这样的。后来我想到了曾看过的一个load()方法的教程里,讲的callback,这个以前我以为是针对load状态进行的反应,比如如果load失败可以通过这个显示一个什么之类的。现在记起来了,当时那个教程里不是将load过来的内容淡入展现吗?

这应该就是问题的关键了,于是我将prettyPrint()放入callback中,果然代码高亮出现了。

于是我知道了,load()方法里的内容的生命周期只在这个load方法之内,过了就再也找不到了!要给其中的内容应用js,需要统统放到callback里!

具体代码如下:

 

$XX.load(url,function(){prettyPrint();})

 

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
移動(dòng)開發(fā)工程師
手記
粉絲
39
獲贊與收藏
245

關(guān)注作者,訂閱最新文章

閱讀免費(fèi)教程

  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消