JavaScript动态创建link标签到head⾥的⽅法
本⽂实例讲述了JavaScript动态创建link标签到head⾥的⽅法。分享给⼤家供⼤家参考。具体分析如下:
相信有很多做前端的朋友碰到过需要⽤ JavaScript 动态创建样式表标签——link标签。这⾥我们就来说说如何在浏览器中动态创建link标签。
使⽤ jQuery 创建 link 标签
css怎么创建如果你开发中喜欢⽤jQuery,那么⽤jQuery在创建link标签应该是这样的:
复制代码代码如下:
var cssURL = '/style.css',
linkTag = $('<link href="' + cssURL + '" rel="stylesheet" type="text/css" media="' + (media || "all") + '" charset="'+ charset || "utf-8" +'" />');
// 请看清楚,是动态将link标签添加到head⾥
$($('head')[0]).append(linkTag);
使⽤原⽣ JavaScript 创建 link 标签
如果你喜欢纯天然的 JavaScript,就要需要这么写:
复制代码代码如下:
var head = ElementsByTagName('head')[0],
cssURL = '/style.css',
linkTag = ateElement('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 = ElementsByTagName('head')[0],
cssURL = 'themes/BlueNight/style.css',
// ateStyleSheet 的同时就已经把link标签添加到了head中了,怎么讲呢,倒是挺⽅便
linkTag = ateStyleSheet(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 = $('<link href="' + cssURL + '" rel="stylesheet" type="text/css" media="' + (media || "all") + '" charset="'+ charset || "utf-8" +'" />');
head.append(linkTag);
}
function createLink(cssURL,lnkId,charset,media){
var head = ElementsByTagName('head')[0], linkTag = null;
if(!cssURL){
return false;
}
linkTag = ateElement('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程序设计有所帮助。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论