失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > JavaScript 高级篇之DOM文档 简单封装及调用 动态添加 删除样式(六)

JavaScript 高级篇之DOM文档 简单封装及调用 动态添加 删除样式(六)

时间:2019-02-26 21:54:15

相关推荐

JavaScript 高级篇之DOM文档 简单封装及调用 动态添加 删除样式(六)

web前端|js教程

DOM文档,简单封装及调用,动态添加,删除样式

web前端-js教程

/TomXu/archive//02/16/2351331.html , 在回来看这里文章,你一定会有更深刻的认识。因为我在这里介绍概念上的东西比较少,看下面的例子,对初学的朋友可能会有些吃力!

园艺购物网站源码,vscode 跳到源码,ubuntu系统网口灯不亮,正确开关tomcat,sqlite 自动写命令,百度插件库,淘宝用的前端框架,免费学python爬虫,php保存数据库,SEO大牛翻糖,医院网站模板html5整站,网页悬浮图片代码,订餐系统后台模板素材,织梦贷款页面,java合同管理系统免费版,YGBOOK小说采集程序6.14lzw

1、DOM的架构

asp源码 摄影图片,vscode没有虚拟环境,esxi装ubuntu,文件在tomcat启动,爬虫攻击原理,sae php 版本,新型seo外包热线电话,腾讯网站特效,bootstrap登录模板手机lzw

document

CSS Demo

我喜欢美女,特别是高个的美女

asp源码 会员管理系统,vscode 全选,ubuntu ctex,tomcat 0800,Ado访问sqlite,服务器遭到攻击,手机端弹窗多选插件,前端 数据展示框架,网络爬虫的历史,徐州php工资,seo玖月,政府网站红色模板,手机网页划屏设置,淘宝免费专业版模板下载,微信h5页面免费模板下载,bs订单管理系统模板,小游戏 源程序 下载lzw

这个文档的DOM表示如下图:

图片表示一个HTML文档的树.

所有DOM树结构表现为不同种类的Node对象的一个数,firstChild,lastChild,nextSibling,previousSibling和ParentNode属性提供遍历节点的树的一种办法,appendChild,removeChild,replaceChildh和insertBefore这样的方法可以像文档中添加节点或者从文档中删除节点。不明白没关系接下来我将用大量的例子让你明白。

1、先创建一个使用CSS美化的列表

body{ margin:0px; padding:0px; }

#container{font-family:tahoma;font-size:14px;border:solid 1px #99ffcc; width:200px;height:140px; float:left; }

#container ul{list-style:none;padding:1px 0px 0px 0px; margin:0px;}

#container ul li{ border-bottom:solid 1px #99ffcc; margin:0px;height:27px;}

#container ul li a{background-color:gray;text-decoration:none;display:block; border-left:solid 10px red;margin:0px; padding:5px 0px 5px 10px;}

#container ul li a:hover{background-color:red; color:#000000; }

2、加一个div 元素.

Home

MyBlog

Sport

News

Contane

3、你现在应该看到如下图:

4、根据上图获取元素总数

var Tools = {};

Tools.getElementCount = function(e){

var count =0;

elementTotal(e);

document.table.txt.value = "element:"+ count;

function elementTotal(e)

{

if(e.nodeType == 1) count++;

var children = e.childNodes;

for(var i = 0;i<children.length;i++)

{

elementTotal(children[i]);

}

}

};

备注:大家使用可以再body加入

5、将文本全部大写

Tools.ModifyElement = function modify(e){

if(e.nodeType == 3)

e.data = e.data.toUpperCase();

else

{

for(var i = e.firstChild;i!=null;i=i.nextSibling)

modify(i);

}

};

备注:大家使用可以再body加入

效果:

6、给列表排序

Tools.documentSort = function(e){

var textArray = [];

if(typeof e =="string") e = document.getElementById(e);

for(var x = e.firstChild; x!= null;x=x.nextSibling)

if(x.nodeType == 1) textArray.push(x);

textArray.sort(function(n,m){

var s = n.firstChild.firstChild.data;

var t = m.firstChild.firstChild.data;

if(s>t) return -1;

else if(s<t) return 1;

else return 0;

});

备注:大家使用可以再body加入

效果:

7、动态插入列表项(子节点)

Tools.insertElement = function(n,e){

if(typeof n == "string") n = document.getElementById(n);

var li = document.createElement(e);

var a = document.createElement("a");

a.setAttribute("href","#");

var txt = document.createTextNode("HotBlog");

a.appendChild(txt);

li.appendChild(a);

var parent = n.parentNode;

parent.insertBefore(li,n);

};

备注:大家使用可以再body加入

效果:

8、使用javascript类动态创建文档

1、样式表

.tooltip{background:url(2.jpg); border:solid 1px #99ffcc; width:200px;height:200px;}//这里的图片大家要该一下

.toolcontent{background-color:#ffffff; border:solid 1px #99ff00; padding:5px; font:tahoma 12px; color:#000000;}

2、javascript类

function Tooltip()

{

this.tooltip = document.createElement("div");

this.tooltip.style.position = "absolute";

this.tooltip.className = "tooltip";

this.content = document.createElement("div");

this.content.style.position = "relative";

this.content.className = "toolcontent";

this.tooltip.appendChild(this.content);

}

Tooltip.prototype.show = function(text,x,y)

{

this.content.innerHTML = text;

this.tooltip.style.left = x+"px";

this.tooltip.style.top = y+"px";

this.tooltip.style.visibility = "visible";

if(this.tooltip.parentNode != document.body)

document.body.appendChild(this.tooltip);

};

Tooltip.prototype.hide = function(){ this.tooltip.style.visibility ="hidden";};

var t = new Tooltip();

function hide()

{

t.hide();

}

function show()

{

t.show("hello ",300,0);

}

function init()

{

document.operator.show.onclick = show;

document.operator.hide.onclick = hide;

}

备注:配合上面使用必须还完成以下步骤:1、将body中的onload=init();2 在body中添加 :

效果:(隐藏看到什么了)

9、动态添加样式和删除样式

1、样式表

.container{font-family:tahoma;font-size:14px;border:solid 1px #99ffcc; width:200px;height:140px;float:left;}

.container ul{list-style:none;padding:1px 0px 0px 0px; margin:0px;}

.container ul li{ border-bottom:solid 1px #99ffcc; margin:0px;height:27px;}

.container ul li a{background-color:gray;text-decoration:none;display:block; border-left:solid 10px red;margin:0px; padding:5px 0px 5px 10px;}

.container ul li a:hover{background-color:red; color:#ffffff; }

2、工具函数(动态添加、删除样式)

var CSSclass = {};

CSSclass.is = function(e,c){

if(typeof e == "string") e = document.getElementById(e);

var classes = e.className;

if(!classes) return false;

if(classes == c) return true;

return e.className.search("\\b" +c +"\\b*") != -1;

};

CSSclass.add = function(e,c){

if(typeof e == "string") e = document.getElementById(e);

if(CSSclass.is(e,c))return;

//if(e.className) c=""+c;

e.className += c;

};

CSSclass.remove = function(e,c){

if(typeof e == "string") e = document.getElementById(e);

//e.id = e.id.replace(new RegExp("\\b" +e.id +"\\b\\s*","g"),"");

e.className = e.className.replace(new RegExp("\\b"+c+"\\b\\s*","g"),"");

};

3、在body中加入如下元素

Home

MyBlog

Sport

News

Content

效果:

没添加样式的样子

加了样式之后。

小结:Dom文档操作、内联样式、动态设置样式等就给大家分享到这里吧!其实还有很多细节没给大家呈现。下一篇我将分享我学习事件的历程。

(很多没有备注,大家有问题可以给我留言!)

如果觉得《JavaScript 高级篇之DOM文档 简单封装及调用 动态添加 删除样式(六)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。