位置: 编程技术 - 正文

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)

  • 建筑业一般纳税人可以开3%的发票吗
  • 一般纳税人购进货物用于免征增值税项目
  • 嵌入式软件产品的增值税即征即退具体实例
  • 发票连续作废两次
  • 其他个人出租房屋按照多少征收应纳税额
  • 税前利润包含营业税吗
  • 发生采购业务无合同需要缴印花税吗
  • 工资中事假扣款执行依据
  • 未开业零升报企业是否做年度汇算清缴申报
  • 企业资产折旧抵扣所得税
  • 财务费用利息收入借方为负数是什么意思
  • 税务部门罚没收入200元
  • 补开的银行手续费发票怎么做账
  • 2018年债券基金
  • 建筑工程安装合同
  • 应付职工薪酬会计科目怎么做
  • 金税三期得死多少企业
  • 个人所得税成本费用怎么算
  • 商品退回顺丰代收怎么办
  • 奖金属于工资吗?要交税吗?
  • windows11怎么安装iis
  • mac屏幕共享要打开什么权限
  • php常用函数
  • php缓存机制有哪些
  • 电脑开机弹出网页游戏广告
  • window10今天更新
  • 劳务费要申报个税吗怎么申报
  • 怎么获得win10纯净版
  • 逾期未收回包装物押金税率
  • 发票抵扣条件
  • 移动列表格
  • thinkphp技巧
  • react router教程
  • 使用nvm安装nodejs后无法执行node命令
  • php fopen()
  • 支付价款含不含增值税
  • 企业所得税季度申报表怎么填
  • 残疾人保证金的滞纳金怎么计算
  • 非企业指的是什么
  • 企业没有研发费用怎么做账
  • distinct用法及搭配
  • 以非货币性资产对外投资会计处理
  • 劳务公司是怎么运作的
  • 对于投资者而言购买债券型理财产品面临的最大风险来自
  • 解决在sql脚本中怎么写
  • 企业接受捐赠增值税处理
  • 利润表中本月数,本期金额指什么
  • 收到房租的租金怎么做账
  • 进项税额加计10
  • 个体工商户员工如何报生育险
  • 小规模减免税收入
  • 计提工资的会计处理
  • 营业外支出增加说明了什么
  • 银行存款付款是借方还是贷方
  • 民办非企业可以开发票吗
  • 挂靠工程项目预交税金的会计分录如何做?
  • 公司向股东借款多久必须归还
  • win10 mysql 5.6.35 winx64免安装版配置教程
  • sqlserver数据库事物日志已满
  • ghost重装步骤
  • Ubuntu 8.10 Intrepid Ibex Alpha4 官方正式版下载
  • xp系统的设置在哪里
  • windows8开机启动项在哪里设置
  • win8开机进不了桌面
  • win7装win8系统教程
  • linux 怎么样
  • cocos2d怎么用
  • linux中argv
  • 移动端一般用什么布局
  • android view详解
  • asp.net 4.8
  • window.requestAnimationFrame是什么意思,怎么用
  • html js怎么调用
  • javascript:download()
  • 深圳国税电子税务局
  • 济南税务局电话是多少
  • 增值税税控开票软件升级
  • 根据消费税暂行条例的规定,纳税人自产自用
  • 办理税务需要开户许可证吗
  • 公务卡信用等级1级
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设