位置: 编程技术 - 正文

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)

  • 增值税滞纳金怎么做账
  • 用友t6会计科目在哪里找
  • 公司欠款利息收入需要交增值税吗?
  • 其他应付款转实收资本有风险吗
  • 收据盖公章要注意哪些
  • 母公司捐赠资金给子公司
  • 贷款利息收入的税率是多少
  • 上个月没有结账可以做下个月的账吗
  • 抵账房产财务入账
  • 应付账款扣除商业折扣
  • 出口企业如何做锁汇
  • 进货费用会计科目
  • 材料发票不够怎么办
  • 个人独资企业所得税
  • 2017年金税盘服务费已全额减免,勾选系统怎么处理
  • 航天信息300元是什么费用
  • 差额征税的差额怎么算
  • 质量扣款不开票怎么处理
  • 土地的契税和印花税记入什么科目
  • 个体定税标准
  • 华为matex3价格表
  • 最新早上好图片大全集
  • 王者荣耀中墨子的最强出装
  • 事业单位收入需要缴纳所得税吗
  • 预缴增值税附加税款怎么填写申报表
  • 赠品促销怎么做
  • 农民工工资保证金退还条件
  • 小规模纳税人结转免交增值税
  • php公众号推送完整示例
  • 超出经营范围开票怎么处理
  • thinkphp框架介绍
  • 酒店客房成本构成
  • iconfont原理
  • vue面试题2020
  • mysql分区实现
  • 固定资产类别有哪些
  • 转让旧机器的会计分录
  • 销售旧货物的增值税
  • 以前年度损益调整属于哪类科目
  • 企业报税流程是什么样的
  • 接待客人后的感受和过程
  • 车户过户
  • 公司注销后违法行为追究吗
  • 暂估金额与发票金额的区别
  • 存款基准利率是不是利息
  • 企业间贴现手续怎么办理
  • 对公账户收到钱有提示吗
  • 银行回单超过三个月可以补打吗
  • 建筑工程拨款申请模板
  • 账面净值什么意思
  • 生鲜配送账务处罚标准
  • 备查账的登记主要以什么来表述
  • 寻找sql注入漏洞存在哪几个关键点
  • 通过T-SQL语句实现数据库备份与还原的代码
  • iis w3svc
  • linux系统vim编辑readonly option
  • win8n
  • 怎么提高xp系统运行速度
  • Linux Mint 5 XFCE Community Edition RC1 (BETA 025) 本月17日开始发布
  • gage blocks是什么意思
  • linux安装glibc.i686
  • Win10 Build 10586.107正式推送 主要修复bug
  • win10系统出现问题怎么办
  • javascript编程规范
  • winbox app
  • Extjs4 GridPanel 的几种样式使用介绍
  • How to embed a jframe in an eclipse view
  • python的删除
  • unity局域网多人游戏
  • 安卓开源组件
  • javascript面向对象精要pdf下载
  • 四川省国税局一处处长
  • 已知税率怎么求政府税收
  • 河南12306区号
  • 重庆市电费网上查询
  • 江苏省官网
  • 新税法折旧年限怎么算
  • 为什么经常收到税务短信
  • 财税相关书籍
  • 税务总局四个确保
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设