分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

动态加载js和css

发布时间:2023-09-06 01:37责任编辑:沈小雨关键词:js

一、动态加载CSS
动态创建css样式有两种方式:
1、动态插入css外部文件的方法:
function loadStyle(url){
  var link = document.createElement(‘link‘);
    link.type = ‘text/css‘;
    link.rel = ‘stylesheet‘;
    link.href = url;
    var head = document.getElementsByTagName(‘head‘)[0];
    head.appendChild(link);
}
loadStyle(‘test.css‘);

2、动态加载css代码片段

function loadCssCode(code){
var style = document.createElement(‘style‘);
    style.type = ‘text/css‘;
    style.rel = ‘stylesheet‘;
    try{
        //for Chrome Firefox Opera Safari
        style .appendChild(document.createTextNode(code));
    }catch(ex){
        //for IE
        style.styleSheet.cssText = code;
    }
    var head = document.getElementsByTagName(‘head‘)[0];
    head.appendChild(style);
}
loadCssCode(‘body{background-color:#f00}‘);

二、动态加载js

1、异步加载,并加载到前台资源库

function loadJsCallback(sid, jsurl, callback) {
 var nodeHead = document.getElementsByTagName(‘head‘)[0];
 var urlStr = jsurl.split(‘,‘);
 if(document.getElementById(sid + "JS0") == null){
  var urlLength = urlStr.length;
  for(var i = 0; i < urlStr.length; i++){
   var nodeScript = document.createElement(‘script‘);
   nodeScript.setAttribute(‘type‘, ‘text/javascript‘);
   nodeScript.setAttribute(‘src‘, urlStr[i]);
   nodeScript.setAttribute(‘id‘, sid + ‘JS‘ + i);
   if(callback != null){
    nodeScript.onload = nodeScript.onreadystatechange = function(curTarget) {
     if(nodeScript.ready){
      return false;
     }
     if(!nodeScript.readyState || nodeScript.readyState == "loaded"
       || nodeScript.readyState == ‘complete‘){
      urlLength -= 1;
      if(0 != urlLength){
       return false;
      }else{
       nodeScript.ready = true;
       callback();
      }
     }
    };
   }
   nodeHead.appendChild(nodeScript);
  }
 }else{
  if(callback != null){
   callback();
  }
 }
}

 



动态加载js和css

原文地址:https://www.cnblogs.com/jzgd/p/8318337.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved