位置: 编程技术 - 正文

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)

  • 金税盘开票系统怎么增加税目
  • 未开票收入次月如何申报增值税
  • 转让不动产取得的收入
  • 调整多计提所得税的分录
  • 怎么用一证通报税
  • 公司给员工报销话费怎么做账
  • 第二季度的季初资产总额和季末资产总额怎么填
  • 厂家订货会合同
  • 有限合伙企业中有限合伙人承担责任的方式为
  • 公司从个人手中租房不能取得发票
  • 五险一金账务处理流程图
  • 公司出差是自己先垫付再报账吗
  • 重复做了以前做过的梦
  • 企业开出增值税专用发票后注销
  • 纳税人为风险纳税人
  • 收取职工房租 算收入吗
  • 简并增值税税率政策解读
  • 单位报销托儿费
  • 在建工程完工,并当日签订出租协议的会计分录
  • 最新土地增值税实施细则
  • 平销返利可以作为下期的折扣开票吗?
  • 代付给其他供应商货物尾款怎么记账
  • 固定资产折旧金额影响因素
  • 先征后退房产税的会计处理?
  • 家具属于固定资产什么类别
  • 发票先入账,但发票不对
  • macbookpro提醒事项
  • 购进材料是进项税还是销项税
  • 信息化投入费用包括哪些
  • 库存现金的主要内容有哪些
  • adb是什么程序
  • mac应用程序图标
  • 潘塔纳尔湿地的成因
  • 怎么开通公众号微信公众平台
  • php判断字符串长度的方法
  • 财政拨款结转的明细科目中,年末结转后有余额的是
  • water gardens
  • 固定资产清理的审计目标不包括
  • 通往海滩的木板有什么用
  • thinkphp常用函数
  • 怎么安装离线导航
  • viwer.js
  • Vue项目打包
  • pilot coat
  • css设置背景图片填充
  • 售后租回交易的资产销售价低于市场价承租人作为
  • 法人想从公司户提钱自己用有事吗
  • 发票报销可以跨年吗
  • java自增自减运算符的规则
  • 社保稳岗补贴怎么查询
  • 财务费用应付利息
  • 股东投资款超过注册资金的案例
  • 体检入账的原始凭证是
  • 利润表中财务费用中的利息费用和利息收入
  • 为什么购入股票是综股
  • 公司收到美元怎么交税啊
  • 购买税控系统分录
  • 记账凭证模板
  • mysql和mysql数据库的区别
  • sqlserver not in 语句使程充崩溃
  • sql中的非逻辑
  • win7电脑默认打开方式怎么设置
  • ramaint.exe - ramaint是什么进程 有什么用
  • mac不小心把硬盘删了怎么办
  • Msssrv.exe - Msssrv是什么进程 有什么用
  • windows7播放器无法打开
  • win10的显示
  • win10网络共享失败
  • win7安装内存4g
  • Linux安装完mysql后提示错误无法登陆mysql怎么办?
  • unity3d技术介绍
  • node.js底层原理
  • linux for i in
  • Node.js中的事件循环是什么意思
  • python操作微信自动发消息
  • 长春市税务局电话号
  • 国税总局网
  • 如何打印个人所得税明细
  • 专利转让个人所得税率
  • 跨区域涉税事项报告表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设