本文實例講述了JavaScript動態創建link標簽到head裡的方法。分享給大家供大家參考。具體分析如下:
相信有很多做前端的朋友碰到過需要用 JavaScript 動態創建樣式表標簽——link標簽。這裡我們就來說說如何在浏覽器中動態創建link標簽。
使用 jQuery 創建 link 標簽
如果你開發中喜歡用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 = 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 = $('<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 = 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程序設計有所幫助。