原生js——与text有关的属性、方法:appendData()、deleteData()、insertData()、createTextNode()、splitText()……

原生js——与text有关的属性、方法

1.属性、属性值:
  • .nodeType:;
  • .nodeName:#text;
  • .nodeValue (也可以通过data属性来访问 ):标签里面的文本内容;
  • .parentNode:Element;
  • 无子节点
    若要查看其他属性值,直接在控制台输出即可;
2.方法:
  • appendData( textContent ):在节点末尾插入指定的文本内容;
  • deleteData( index,count ):从索引为index的位置开始删除count个字符;
  • insertData( index,textContent ):在索引为index的位置上插入文本内容;
  • replaceData( index,count,textContent ):用 textContent 替换从index指定的位置开始到 (offset + count) 止的文本;
  • splitText( index ):从索引为index的位置将该文本节点分割成两个文本节点;
  • normalize:规范化文本节点(将相邻的文本节点合并成一个文本节点),这个方法不是文本节点自身的,而是文本节点的父级元素的。
  • substringDate( index, count ):提取从index指定的位置开始到(index + count)为止的字符串;

注:一个标签只有一个文本节点( 但动态添加文本节点则不同

<!--有一个空格,有一个文本节点-->
	<p> </p>
<!--包含空格,包含文本,有一个文本节点-->
	<p>有一个  文本节点;</p>
<!--空标签,无文本节点-->
	<p></p>

举例

	<div>哈哈哈哈</div>
	var div = document.querySelector("div");
	 //这里缺少一行代码,控制台会报一个错误;
	console.log(div.nodeValue);
	div.appendData("原来是这样"); 
	console.log(div.nodeValue);

输出的结果:( 因为我们获取到的是元素节点div,而非文本节点,望牢记:获取元素节点的文本节点一般情况就是.firstChild; )
Alt所以,完整的代码如下:

	var div = document.querySelector("div");
	var divText = div.firstChild; //这一步至关重要,要留心,不然就会发生以上的错误;
	console.log(divText.nodeValue);
	divText.appendData("原来是这样");
	console.log(divText.nodeValue);	

结果如下:
Alt

扩展:

注意文本中的转义字符( 跟文档类型的编码有关 ):

	divText.data = "<p>有 空格</p>";
	console.log( divText.data);

可能看到以下两种结果:

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

男孩子小杨

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值