js html 新增link,JavaScript动态创建link标签到head里的方法

本文详细介绍了如何使用JavaScript动态创建link标签并将其添加到head中,包括使用jQuery和原生JavaScript的方式,以及IE特有的createStyleSheet方法。通过这些方法,可以实现在网页运行时动态加载CSS样式表。
摘要由CSDN通过智能技术生成

本文实例讲述了JavaScript动态创建link标签到head里的方法。分享给大家供大家参考。具体分析如下:

相信有很多做前端的朋友碰到过需要用 JavaScript 动态创建样式表标签——link标签。这里我们就来说说如何在浏览器中动态创建link标签。

使用 jQuery 创建 link 标签

如果你开发中喜欢用jQuery,那么用jQuery在创建link标签应该是这样的:

var cssURL = '/style.css',

linkTag = $('');

// 请看清楚,是动态将link标签添加到head里

$($('head')[0]).append(linkTag);

使用原生 JavaScript 创建 link 标签

如果你喜欢纯天然的 JavaScript,就要需要这么写:

var head = document.getElementsByTagName('head')[0],

cssURL = '/style.css',

linkTag = document.createElement('link');

linkTag.id = 'dynamic-style';

linkTag.href = cssURL;

linkTag.setAttribute('rel','stylesheet');

linkTag.setAttribute('media','all');

linkTag.setAttribute('type','text/css');

head.appendChild(linkTag);

IE 里特有的方法 createStyleSheet

IE 里特有的方法 createStyleSheet 方法也是很方便。

var head = document.getElementsByTagName('head')[0],

cssURL = 'themes/BlueNight/style.css',

// document.createStyleSheet 的同时就已经把link标签添加到了head中了,怎么讲呢,倒是挺方便

linkTag = document.createStyleSheet(cssURL);

createStyleSheet( [sURL] [, iIndex])方法接受两个参数,sURL就是CSS文件的URL路径。iIndex 为可选参数,指插入的link在页面中stylesheets collection的索引位置,默认是在最后添加新创建的样式。

完整的解决方案

基本上都介绍完了,来看看完整的解决方案吧:

function createLink(cssURL,lnkId,charset,media){

var head = $($('head')[0]),

linkTag = null;

if(!cssURL){

return false;

}

linkTag = $('');

head.append(linkTag);

}

function createLink(cssURL,lnkId,charset,media){

var head = document.getElementsByTagName('head')[0],

linkTag = null;

if(!cssURL){

return false;

}

linkTag = document.createElement('link');

linkTag.setAttribute('id',(lnkId || 'dynamic-style'));

linkTag.setAttribute('rel','stylesheet');

linkTag.setAttribute('charset',(charset || 'utf-8'));

linkTag.setAttribute('media',(media||'all'));

linkTag.setAttribute('type','text/css');

linkTag.href = cssURL;

head.appendChild(linkTag);

}

希望本文所述对大家的javascript程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值