这篇文章主要介绍了 JavaScript 动态创建 link 标签到 head 里的方法, 分别介绍了使用 jQuery 的方法、使用原生 javascript 方法与 IE 特有的 createStyleSheet 方法等, 非常具有实用价值, 需要的朋友可以参考下
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
本文实例讲述了 JavaScript 动态创建 link 标签到 head 里的方法。分享给大家供大家参考。具体分析如下:
相信有很多做前端的朋友碰到过需要用 JavaScript 动态创建样式表标签——link 标签。这里我们就来说说如何在浏览器中动态创建 link 标签。
使用原生 JavaScript 创建 link 标签如果你喜欢纯天然的 JavaScript,就要需要这么写:
IE 里特有的方法 createStyleSheet
- 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 方法也是很方便。
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 程序设计有所帮助。
来源: