位置: 编程技术 - 正文

Javascript动态引用CSS文件的2种方法介绍(js动态引入css文件)

编辑:rootadmin

最近做一个项目,需要javascript动态插入样式,结果以前的方法失效了!查了2个小时的原因竟然是自己手贱,这个最后再说!

javascript插入样式在前端开发中应用比较广泛,特别是在修改前端表现和页面换肤的时候。最近做的这个任务是用户在别人的站点上点击一个按钮,就会在别的站点页面下插入一个脚本,执行,这其中包含了样式的插入。

一般情况下javascript动态插入样式有两种,一种页面中引入外部样式,在<head>中使用<link>标签引入一个外部样式文件,另一种是在页面中使用<style>标签插入页面样式(这里说的不是style属性)。

一、页面中引入外部样式:

在<head>中使用<link>标签引入一个外部样式文件,这个比较简单,各个主流浏览器也不存在兼容性问题:

但是在我目前做的这个项目中本身应用的样式非常少,直接用引入一个外部样式文件似乎不合适,所以我选择了第二种方案,在页面中使用<style>标签插入页面样式。

二、使用<style>标签插入页面样式:

这种方式在各个主流浏览器存在兼容性问题,像firefox等标准浏览器无法直接获取设置styleSheet的cssText值,标准浏览器下只能使用document.styleSheets[0].cssRules[0].cssText单个获取样式;同时使用:document.styleSheets[0].cssRules[0].cssText=newcssText;页面不会自动更新样式,必须使用:document.styleSheets[0].cssRules[0].style.cssText=newcssText;这点似乎没坑爹的IE来的人性化和简便。YUI中使用了一个很好的办法:style.appendChild(document.createTextNode(styles));采用createTextNode将样式字符串添加到<style>标签内;

这样页面中的元素就能直接应用样式了,不管你的这些元素是不是通过脚本追加的。

关于手贱:

看这段代码:

前面说了这个项目是用户在别人的站点上点击一个按钮,就会在别的站点页面下插入一个脚本,执行,这其中包含了样式的插入,我为了尽可能的保证我创建的元素ID唯一性,手贱在元素ID前加了“__”,表示私有防止冲突。结果悲剧了,IE6,IE7 class和id的命名不能以下划线开头(“_”),竟然把这个给忘了!花了两个小时才找到原因。悲剧啊!得出一个结论!做前端千万不能手贱!

推荐整理分享Javascript动态引用CSS文件的2种方法介绍(js动态引入css文件),希望有所帮助,仅作参考,欢迎阅读内容。

Javascript动态引用CSS文件的2种方法介绍(js动态引入css文件)

文章相关热门搜索词:js动态引入js,jsp动态引入和静态引入区别,jsp动态引入,js动态引入css,js动态调用方法,js动态调用方法,js动态调用方法,js动态引入css,内容如对您有帮助,希望把文章链接给更多的朋友!

js中的caller和callee属性介绍和例子 一、caller返回一个对函数的引用,该函数调用了当前函数。functionName.callerfunctionName对象是所执行函数的名称。说明对于函数来说,caller属性只有在函数

ECMAScript6的新特性箭头函数(Arrow Function)详细介绍 箭头函数是ECMAScript6最受关注的更新内容之一。它引入了一种用「箭头」(=)来定义函数的新语法,它…它碉堡了~。箭头函数与传统的JavaScript函数主要

javascript浏览器兼容教程之事件处理 1.window.event【分析说明】先看一段代码functionet(){alert(event);//IE:[object]}以上代码在IE运行的结果是[object],而在Firefox无法运行。因为在IE中event作为window对

标签: js动态引入css文件

本文链接地址:https://www.jiuchutong.com/biancheng/370156.html 转载请保留说明!

上一篇:Javascript中的delete操作符详细介绍(JavaScript中的数据类型分为两大类)

下一篇:js中的caller和callee属性介绍和例子(js call.call)

  • 员工工资薪金会计如何核算?
  • 不动产抵扣进项税
  • 定额备用金补付会计分录怎么写?
  • 公司股东可以自己买保险吗
  • 以前年度的负债没挂账怎么办
  • 房地产营改增后开票
  • 环境保护税由什么部门负责征收管理
  • 公司业务招待费占比
  • 发票金额与支票数量不符
  • 餐饮外卖的经营范围是什么项目
  • 今年交上年税审核要多久
  • 免税销售额对应的进项税额
  • 补缴的公积金可以取出来吗
  • 出口退税增值税发票稽核信息
  • 个体工商户开税票怎么开
  • 一次性收取一年租金
  • 季度所得税缴纳时间规定
  • 组策略在哪里
  • 资产划转的账务处理
  • 未分配利润转增股本交印花税
  • PHP:mime_content_type()的用法_fileinfo函数
  • 出差补贴怎么记账
  • 三方债权债务抵消如何开发票
  • vue unknown custom element
  • 房地产开发企业增值税怎么算
  • php 反代
  • 知识产权专利费包括哪些费用
  • Python 计算机视觉(八)—— OpenCV 进行图像增强
  • 利息收入做红字
  • 人工智能助力中国创新发展
  • 异常处理流程为哪几个部分
  • 应届生优势大吗
  • php curl_multi_init
  • 小规模增值税减征额怎么算
  • 职工福利能开专票吗
  • 进项加计抵减会计分录怎么做
  • markdown小小白常用语法
  • 免征企业所得税的有哪些行业
  • java静态方法和动态方法的区别
  • 坏账准备是什么性质的科目
  • 收到以前年度增值税退税账务处理怎么做账
  • 三证合一后个体交税吗
  • 租厂房需要去缴房产税吗
  • 固定资产报废处置的请示
  • sql编程软件哪个好用
  • 企业应付账款的借方登记
  • 小规模纳税人季报需要报什么
  • 平行结转法什么意思
  • 员工预支钱要写什么单据
  • 发票还没认证可以报销吗
  • 一般纳税人纳税申报表
  • 出售无形资产损失
  • 帮员工代缴社保分录怎么办
  • 哪些企业执行新的租赁政策
  • 各单位应当设置专职能源管理岗位
  • 简述linux几种主流发行版本及其特点
  • wfxsnt40.exe - wfxsnt40是什么进程
  • 操作系统安装日期查看
  • 关于linux操作系统的描述中
  • 不用第三方软件获取鼠标坐标
  • linux网卡bound
  • win7保存桌面不见了怎么办
  • windows8介绍
  • linux 网页
  • win8.1系统更新
  • android打包原理
  • 启动dos快捷键
  • vue中拦截器
  • nodejs yield
  • unity3d all compiler errors
  • unity火堆
  • jquery返回顶部代码
  • jquery编写页面载入事件
  • 契税怎样才能抵扣个税
  • 自用的房产怎么交房产土地税
  • 北京市朝阳区地图
  • 国税官网登录
  • 为什么要进行进气歧管真空度检测
  • 中国移动话费可以交水电费吗
  • 2021年社保又涨价了
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设