位置: 编程技术 - 正文

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)

  • 既简易计税又一般计税的进项专票可以抵扣吗
  • 公司换股东需要本人去吗
  • 风险纳税人是指个人还是单位
  • 税务硕士是什么学位类别
  • 营销活动,单位让现场观众抽现金奖如何入账?
  • 减少实收资本需要缴纳什么税
  • 土地交易服务费属于非税收入吗
  • 费用发票能不能直接挂应付账款里
  • 现金流量表抵消分录
  • 短期借款明细账应采用三栏式账页格式
  • 增值税减免所得税填在哪一栏
  • 个税和社保基数不一致会影响上海落户吗
  • 企业季度报什么税
  • 社保公积金占比多少
  • 单位为个人负担工资、薪金所得的个税,怎么征收个税
  • 合并会计报表调整分录
  • 支付外聘老师的培训费
  • 产权转移书据印花税申报期限
  • 社保和个税怎么个对应法
  • 印花税资金账簿税率是多少
  • 增值税申报进项抵扣汇总表在哪里
  • 收据能不能做账
  • 跨年补交企业所得税
  • 辞退福利怎么交税
  • 土地返还款土地增值税处理
  • 个人购买余额宝安全吗?
  • 怎么查银行账户余额
  • Win10系统cpu性能如何调高 Win10把cpu性能调到极佳的方法
  • 上月印花税计提多了如何冲回
  • 促销礼物
  • 工程决算超预算起诉
  • mac电脑遇到问题而重新启动
  • linux命令top作用
  • scm wms
  • 计提本月所得税费会计分录
  • 偷渡系统可以正常接收到升级吗
  • 外资企业采购退税流程
  • PHP:proc_get_status()的用法_命令行函数
  • 工资薪金支出税前扣除
  • PHP:is_dir()的用法_Filesystem函数
  • thinkphp d
  • 企业代扣代缴个人所得税会计分录
  • 民间非营利组织会计制度
  • php curl代理
  • 个税零申报流程视频教程
  • 微信php接口
  • linux进程状态有哪些
  • 发票融资会计处理
  • 合宪性审查程序
  • 车间买的工具如何做会计分录
  • python如何提取文件中的数据
  • 给客户维修设备更换配件怎么开票
  • 借调是原单位发工资吗
  • sql2008r2如何使用
  • 在业和存续的区别
  • 一般纳税人金税盘怎么清卡
  • 办公费税前扣除标准2023年
  • 法人往自己公司打款没用注明用途
  • 结转后还可以改凭证吗
  • 房地产开发成本费用明细表
  • 上一年度的费用怎么做会计分录
  • 公司发放给员工的福利又要回
  • 被投资企业注销,确认投资损失需
  • 代开的专票作废了怎么做账?
  • 数据库的常用语句
  • microsoft onedrive怎么关闭
  • xp系统怎么更改用户权限
  • ubuntu 网络设置命令
  • ubuntu安装配置静态ip地址
  • win批处理命令
  • cocos2dx入门
  • js绑定函数
  • 将bat文件注册为应用程序
  • jQuery+ajax读取并解析XML文件的方法
  • js clearInterval()方法的定义和用法
  • JavaScript定义变量
  • jquery点击方法
  • wordpress 0day
  • 企业获得的保险公司保险赔偿款收入
  • 经营碎石的税点多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设