博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript 动态加载脚本和样式
阅读量:4180 次
发布时间:2019-05-26

本文共 2551 字,大约阅读时间需要 8 分钟。

 

3大点:

1.元素位置

2.动态脚本

3.动态样式

 

 

一.元素位置

getBoundingClientRect()。这个方法返回一个矩形对象,包含四个属性:lefttoprightbottom。分别表示元素各边与页面上边和左边的距离。

var box = document.getElementById('box');//获取元素

alert(box.getBoundingClientRect().top);//元素上边距离页面上边的距离

alert(box.getBoundingClientRect().right);//元素右边距离页面左边的距离

alert(box.getBoundingClientRect().bottom);//元素下边距离页面上边的距离

alert(box.getBoundingClientRect().left);//元素左边距离页面左边的距离

 

PSIEFirefox3+Opera9.5ChromeSafari支持,在IE中,默认坐标从(2,2)开始计算,导致最终距离比其他浏览器多出两个像素,我们需要做个兼容。

document.documentElement.clientTop;//IE0IE2

document.documentElement.clientLeft;//IE0IE2

 

function getRect(element) {

var rect = element.getBoundingClientRect();

var top = document.documentElement.clientTop;

var left = document.documentElement.clientLeft;

return {

top : rect.top - top,

bottom : rect.bottom - top,

left : rect.left - left,

right : rect.right - left

}

}

PS:分别加上外边据、内边距、边框和滚动条,用于测试所有浏览器是否一致。

 

 

二.动态脚本

var flag = true;//设置true再加载

if (flag) {

loadScript('browserdetect.js');//设置加载的js

}

 

function loadScript(url) {

var script = document.createElement('script');

script.type = 'text/javascript';

script.src = url;

//document.head.appendChild(script);//document.head表示<head>

document.getElementsByTagName('head')[0].appendChild(script);

}

 

PSdocument.head调用,IE不支持,会报错!

 

//动态执行js

var script = document.createElement('script');

script.type = 'text/javascript';

var text = document.createTextNode("alert('Lee')");//IE浏览器报错

script.appendChild(text);

document.getElementsByTagName('head')[0].appendChild(script);

 

PSIE浏览器认为script是特殊元素,不能在访问子节点。为了兼容,可以使用text属性来代替。

script.text = "alert('')";//IE可以支持了。

 

PS:当然,如果不支持text,那么就可以针对不同的浏览器特性来使用不同的方法。这里就忽略写法了。

 

三.动态样式

为了动态的加载样式表,比如切换网站皮肤。样式表有两种方式进行加载,一种是<link>标签,一种是<style>标签。

//动态执行link

var flag = true;

if (flag) {

loadStyles('basic.css');

}

 

function loadStyles(url) {

var link = document.createElement('link');

link.rel = 'stylesheet';

link.type = 'text/css';

link.href = url;

document.getElementsByTagName('head')[0].appendChild(link);

}

 

//动态执行style

var flag = true;

if (flag) {

var style = document.createElement('style');

style.type = 'text/css';

//var box= document.createTextNode(#box{background:red}'); IE不支持

//style.appendChild(box);

document.getElementsByTagName('head')[0].appendChild(style);

insertRule(document.styleSheets[0], '#box', 'background:red', 0);

}

 

function insertRule(sheet, selectorText, cssText, position) {

//如果是非IE

if (sheet.insertRule) {

sheet.insertRule(selectorText + "{" + cssText + "}", position);

//如果是IE

} else if (sheet.addRule) {

sheet.addRule(selectorText, cssText, position);

}

}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

转载地址:http://nfhai.baihongyu.com/

你可能感兴趣的文章
修改Linux系统locale设置
查看>>
linux网络无法连接问题
查看>>
linux 查看ip
查看>>
go中map与xml互转
查看>>
java进程占用CPU过高
查看>>
CSDN-markdown编辑器
查看>>
拷贝整个目录到另一台服务器并排除log目录
查看>>
拜托,面试别再问我跳表了!
查看>>
android ArrayList<String> 转 String[]
查看>>
RecyclerView baseadapter
查看>>
Android中应用程序如何获得系统签名权限
查看>>
Recycler表格(excelPanel)
查看>>
android一行代码实现沉浸式布局效果
查看>>
json, recyclerView问题
查看>>
cmake处理多源文件目录的方法
查看>>
Service Intent must be explicit
查看>>
android studio SDK开发
查看>>
studio 统计代码的行数
查看>>
字符数组和16进制互换
查看>>
PHP项目中出现致命错误: Class 'Redis' not found
查看>>