javascript开发随笔二 动态加载js和文件_javascript技巧
这时候最好的做法就是按需引入,动态引入组件js和样式,文件load完成后调用callback,运行js。代码还是很简便的
1. 判断文件load完成。加载状态ie为onreadystatechange,其他为onload、onerror
if(isie){
Res.onreadystatechange = function(){
if(Res.readyState == 'complete' || Res.readyState == 'loaded'){
Res.onreadystatechange = null;
callback();
_self.loadedUi[modelName] = true;
}
}
}else{
Res.onload = function(){
Res.onload = null;
callback();
_self.loadedUi[modelName] = true;
}
Res.onerror = function(){
throw new Error('res error:' + modelName+'.js');
}
}
2. 所有组件的命名最好保持一致,callback调用也比较方便。还可以根据需要增加参数比如: requires,依赖于那些文件;style,true || false,是否加载样式,等等。
3. 移除操作也可以有,移除script、style标签、delete组件
(function(window,undefined){
if(!window.ui) {
window.ui = {};
}
//动态加载ui的js
window.bus = {
config : {
version : window.config.version,
cssPath : window.config.resServer + '/css/v3/ui',
jsPath : window.config.resServer + '/js/v2/ui'
},
loadedUi : {},
readyStateChange : function(){
var ua = navigator.userAgent.toLowerCase();
return ua.indexOf('msie') >= 0;
},
loadRes : function(modelName,prames,callback){
var _self = this;
var Res = document.createElement(prames.tagName);
for(var k in prames){
if(k != 'tagName'){
Res.setAttribute(k,prames[k],0);
}
}
document.getElementsByTagName('head')[0].appendChild(Res);
if(this.readyStateChange()){
Res.onreadystatechange = function(){
if(Res.readyState == 'complete' || Res.readyState == 'loaded'){
Res.onreadystatechange = null;
callback();
_self.loadedUi[modelName] = true;
}
}
}else{
Res.onload = function(){
Res.onload = null;
callback();
_self.loadedUi[modelName] = true;
}
Res.onerror = function(){
throw new Error('res error:' + modelName+'.js');
}
}
},
removeUi : function(modelName){
if(!modelName){
return true
};
this.loadedUi[modelName] = false;
var head = document.getElementsByTagName('head')[0];
var model_js = document.getElementById('J_model_'+modelName + '_js');
var model_css = document.getElementById('J_model_'+modelName + '_css');
if(model_js && model_css){
delete window.ui[modelName];
head.removeChild(model_js);
head.removeChild(model_css);
return true;
}else{
return false;
}
},
loadUi : function(modelName,callback,setting){
if(!modelName){
return true
};
callback = callback || function(){};
if(this.loadedUi[modelName] == true){
callback();
return true
}
var deafult_setting = {
style : true,
js : true,
requires : []
}
for(var key in setting){
deafult_setting[key] = setting[key];
}
deafult_setting['style'] === true && this.loadRes(modelName,{
id : 'J_model_'+modelName + '_css',
name : modelName,
tagName : 'link',
type : 'text/css',
rel : 'stylesheet',
href : this.config.cssPath + '/' + modelName + '.css?v=' + this.config.version
});
deafult_setting['js'] === true && this.loadRes(modelName,{
id : 'J_model_'+modelName + '_js',
name : modelName,
tagName : 'script',
type : 'text/javascript',
src : this.config.jsPath + '/' + modelName + '.js?v=' + this.config.version
},callback);
if(deafult_setting.requires.length > 0){
for(var i=0,len = deafult_setting.requires.length;i
}
}
}
}
})(window)
使用方法
// load comment for feed
window.bus.loadUi('new_comment_feed', function(){
window.ui.new_comment_feed($("#J_newsList"));
},{
style : false,
requires:['emoticon','addFriend']
});
// load new yy ui
window.bus.loadUi('yy', function(){
window.ui.yy(options);
},{
style:false,
requires:['emoticon']
});
// load photoLightbox
window.bus.loadUi('photoLightbox', function(){
window.ui.photoLightbox(options.urlAjaxGetFriendPhoto, options.urlCommentOtherPhoto,$("#J_newsList"),options.myUid,options.myName);
});

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Python實作無頭瀏覽器擷取應用程式的頁面動態載入與非同步請求處理功能解析在網路爬蟲中,有時需要擷取使用了動態載入或非同步請求的頁面內容。傳統的爬蟲工具對於這類頁面的處理有一定的局限性,無法精確地取得頁面上透過JavaScript產生的內容。而使用無頭瀏覽器則可以解決這個問題。本文將介紹如何使用Python實作無頭瀏覽器來擷取使用動態載入與非同步請求的頁面內容

Vue中處理組件的動態載入和切換Vue是一個流行的JavaScript框架,它提供了各種靈活的功能來處理組件的動態載入和切換。在本文中,我們將討論一些Vue中處理元件動態載入和切換的方法,並提供具體的程式碼範例。動態載入元件是指根據需要在執行時期動態載入元件。這樣可以提高應用程式的效能和載入速度,因為只有當需要時才會載入相關的元件。 Vue提供了async和awa

Golang熱更新原理探究:動態載入與重載的奧秘引言:在軟體開發領域,程式設計師經常希望能夠在不重啟應用的情況下進行程式碼修改和更新。這樣的需求對於開發效率和系統運作的可靠性都具有重要意義。而Golang作為一門現代化的程式語言,為開發者提供了許多便捷的機制來實現熱更新。本文將深入探討Golang熱更新的原理,特別是動態載入和重載的奧秘,並將結合具體的程式碼範例進

如何使用Vue和Element-UI建立動態載入資料的表格在現代的Web開發中,資料表格是常見的介面元件之一。 Vue.js是當下非常受歡迎的前端框架,而Element-UI是基於Vue.js開發的一套元件庫,提供了豐富的UI元件供我們使用。本文將介紹如何使用Vue和Element-UI來建立一個可以動態載入資料的表格,並且給出對應的程式碼範例。首先,我們需要安裝

解決Vue報錯:無法正確使用VueRouter根據路由參數動態載入元件在使用VueRouter進行路由跳轉的過程中,有時我們需要根據路由參數動態載入元件。但是,在某些情況下,我們可能會遇到一個常見的錯誤:無法正確使用VueRouter根據路由參數動態載入元件。本文將介紹如何解決這個報錯,並提供程式碼範例。首先,我們需要明確一點:VueRouter可以透過

C#中如何使用反射和動態載入組件引言:在C#中,反射(Reflection)是一種強大的機制,它允許我們在運行時獲取和操作程式的元數據,包括類型資訊、成員資訊等。而動態載入程式集則是透過反射來實現的常見應用,並且在一些特定場景中非常有用。本文將詳細介紹C#中如何使用反射和動態載入組件,並提供具體的程式碼範例。反射的基本概念反射是C#語言中的重要功能

phpSpider實用技巧:如何處理網頁內容的動態載入問題?在爬取網頁資料時,經常會遇到動態載入的內容無法直接透過爬蟲取得的問題。這些動態載入的內容可以是透過AJAX請求取得的資料、透過JavaScript進行渲染的DOM元素等。為了解決這個問題,本文將介紹一些在使用phpSpider時處理網頁動態載入問題的實用技巧。一、使用網路偵錯工具找出動態載入的URL

Java中使用System類別的load()方法動態載入類別或資源在Java的開發中,有時候我們需要在程式執行時動態地載入類別或資源,以實作一些靈活的功能。 Java提供了System類別的load()方法來實作這個需求。本文將介紹System類別的load()方法的使用,並提供對應的程式碼範例。首先,讓我們來了解一下load()方法的定義:publicstaticvo
