位置: 编程技术 - 正文

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)

  • 没有销项购买税金税盘如何做账
  • 公司车船使用税会计分录
  • 青年企业家协会入会要求
  • 代扣代缴增值税怎么做账
  • 培训咨询企业的发展前景
  • 记账人和复核人是一个人吗
  • 私募基金超募如何购买
  • 销售货物没有开票如何处理
  • 增值税普票没有校验码
  • 坏账准备确认时怎么做账
  • 公司无公务用车
  • 冲暂估成本的会计分录
  • 中意装饰工程有限公司怎么样
  • 公司不动产管理办法
  • 小微企业可以抵税吗
  • 银行承兑汇票到期怎么提示付款
  • 手工发票有效期多久
  • 小规模纳税人代收水电费
  • 产品调试费计入什么科目
  • 第二年缴纳税控盘服务费入什么科目?
  • 增值税多交了怎么申请退税
  • 申请商标发生的费用应该如何入账?
  • 兼职劳务报酬要交个税吗
  • 什么叫冲减进项税额
  • 预付账款和应付账款怎么调账
  • 电脑如何修改硬盘模式
  • 支付的费用没有发票能入费用科目吗
  • 已收到发票未认证已付款怎么做分录
  • 补充医疗税前扣除还是税后扣除
  • 由于找不到msvcr120.dll,无法继续执行代码什么意思
  • 未分配收益怎么取出
  • win7系统把桌面更改为d盘
  • ubuntu设置nginx开机启动
  • php中几个常用的函数
  • 加拿大巨石
  • php执行脚本
  • 长期股权投资采用权益法核算
  • 现金支票应记入什么账户
  • 理财收益如何计税
  • node-gyp版本
  • chkconfig命令参数
  • 自然人税收管理系统
  • lspv命令详解
  • 出口退税进项税额转出怎么申报
  • 向境外企业支付咨询费
  • 资产负债表和利润表的勾稽关系
  • 当月增加的固定资产当月不计提折旧
  • 织梦怎么用
  • 财政借钱给预算单位的会计处理
  • 固定资产一次性折旧政策2023
  • 个人所得税完整申报流程
  • 已认证未申报抵扣怎么办
  • 预付账款和其他应付款的区别
  • 收款单属于什么科目
  • 商业承兑到期对方不付款会计分录
  • 收到税务局汇算清缴退所得税怎么做账
  • 数据库备份sqlserver
  • fedora iso
  • win10如何打开管理
  • dos破解密码输入什么
  • centos7图形安装
  • saproxy.exe - saproxy是什么进程 有什么用
  • win7系统宽带连接错误651
  • windows7如何启动任务管理器
  • win10系统应用更新
  • linux哪里好
  • win10预览模式
  • js opendialog
  • android获取音频信息
  • div+css布局是什么
  • vue-cli使用
  • 小米手机图库图标
  • android四大组件五大布局
  • python所有语句
  • linux0.11编译
  • 增值税发票综合服务平台登录不了
  • 如何查询车辆购买的保险是哪家保险公司
  • 贵州省地方税务局房地产税收征收管理办法
  • 学历认证取消申请还能再申请吗
  • 中国税务客服工作时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设