濮阳杆衣贸易有限公司

主頁 > 知識庫 > Ajax 動態(tài)載入html頁面后不能執(zhí)行其中的js快速解決方法

Ajax 動態(tài)載入html頁面后不能執(zhí)行其中的js快速解決方法

熱門標簽:荊州智能電銷機器人 廣西智能外呼系統(tǒng)多少錢 大學校門地圖標注 平涼高德地圖標注商戶要收費嗎 福建微碼電話機器人 銷售電銷機器人詐騙 外呼系統(tǒng)api對接 地圖標注與公司業(yè)務關系 提高電話機器人接通率

事件背景

有一個公用頁面需要在多個頁面調用,其中涉及到部分js已經寫在了公用頁面中,通過ajax加載該頁面后無法執(zhí)行其中的js。

解決思路

1. 采用附加一個iframe的方法去執(zhí)行js,為我等代碼潔癖者所不齒。

2. 使用document.write輸出代碼,我等簡潔主義者所不愿。

3. 最簡單的方法是把js放到需要調用的父頁面,那想這樣的公用頁面,每個地方調用都要寫入一次,代碼冗余。

4. eval是個解決方法,雖然低效。

5. 復雜的解決方法:正則匹配出加載頁面中的所有js,為這些js創(chuàng)建同樣多個script>標簽,把js內容插入即可執(zhí)行。但使用中發(fā)現(xiàn),firefox可行,但IE還是不從。(師太,您就從了吧~)

解決方案

綜合以上多種方式,排除不利因素,總結出一個比較實用的方法,可以滿足類似這樣公用頁面的執(zhí)行ajax加載的js的需求,在ajax加載的公用函數里面加上代碼即可。主要代碼如下:

// 第一步:匹配加載的頁面中是否含有js
var regDetectJs = /script(.|\n)*?>(.|\n|\r\n)*?\/script>/ig;
var jsContained = ajaxLoadedData.match(regDetectJs); //ajaxLoadedData為ajax獲取到的數據
// 第二步:如果包含js,則一段一段的取出js再加載執(zhí)行
if(jsContained) {
  // 分段取出js正則
  var regGetJS = /script(.|\n)*?>((.|\n|\r\n)*)?\/script>/im;
  // 按順序分段執(zhí)行js
  var jsNums = jsContained.length;
  for (var i=0; ijsNums; i++) {
    var jsSection = jsContained[i].match(regGetJS);
    if(jsSection[2]) {
      if(window.execScript) {
        // 給IE的特殊待遇
        window.execScript(jsSection[2]);
      } else {
        // 給其他大部分瀏覽器用的
        window.eval(jsSection[2]);
      }
    }
  }
}

解說下:window.execScript就IE認,其他瀏覽器需要用eval啦。

總結

以上所述是小編給大家介紹的Ajax 動態(tài)載入html頁面后不能執(zhí)行其中的js快速解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • JS 攔截全局ajax請求實例解析
  • Node.js服務器環(huán)境下使用Mock.js攔截AJAX請求的教程
  • js 實現(xiàn)ajax發(fā)送步驟過程詳解
  • Ajax跨域問題及解決方案(jsonp,cors)
  • $.ajax中contentType: “application/json” 的用法詳解
  • ajax獲得json對象數組 循環(huán)輸出數據的方法
  • 通過jquery的ajax請求本地的json文件方法
  • javascript寫一個ajax自動攔截并下載數據代碼實例

標簽:樂山 邯鄲 德陽 衡陽 黔東 婁底 海南 內江

巨人網絡通訊聲明:本文標題《Ajax 動態(tài)載入html頁面后不能執(zhí)行其中的js快速解決方法》,本文關鍵詞  Ajax,動態(tài),載入,html,頁面,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Ajax 動態(tài)載入html頁面后不能執(zhí)行其中的js快速解決方法》相關的同類信息!
  • 本頁收集關于Ajax 動態(tài)載入html頁面后不能執(zhí)行其中的js快速解決方法的相關信息資訊供網民參考!
  • 推薦文章
    尚义县| 会理县| 庆云县| 正镶白旗| 来凤县| 县级市| 红河县| 天祝| 博白县| 调兵山市| 民勤县| 夹江县| 花莲县| 蕲春县| 阳东县| 新巴尔虎左旗| 伽师县| 滨海县| 吉安市| 金堂县| 噶尔县| 耿马| 定边县| 崇信县| 五峰| 贵定县| 修水县| 霞浦县| 济宁市| 宁安市| 屯门区| 台湾省| 个旧市| 历史| 富平县| 竹山县| 禄劝| 清河县| 南平市| 江门市| 霍城县|