JavaScript動態建立link標籤到head裡的方法,linkhead

來源:互聯網
上載者:User

JavaScript動態建立link標籤到head裡的方法,linkhead

本文執行個體講述了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程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.