这篇文章主要介绍了JavaScript中textContent、innerText和innerHTML的用法以及区别,需要的朋友可以参考下
一.textContent的用法
1.设置标签中的文本内容
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
document.getElementById("btn").onclick = function () {
document.getElementById("dv").textContent = "改变了";
};
</script>
</body>
2.获取标签中的文本内容
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
document.getElementById("btn").onclick = function () {
var text = document.getElementById("dv").textContent;
console.log(text);
};
</script>
</body>
二.innerText的用法
1.设置标签中的文本内容
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
document.getElementById("btn").onclick = function () {
document.getElementById("dv").innerText = "改变了";
};
</script>
</body>
2.获取标签中的文本内容
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
document.getElementById("btn").onclick = function () {
var text = document.getElementById("dv").innerText;
console.log(text);
};
</script>
</body>
三.innerHTML的用法 1.设置标签中的文本内容
1.设置标签中的文本内容
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
document.getElementById("btn").onclick = function () {
document.getElementById("dv").innerHTML = "改变了";
};
</script>
</body>
2.获取标签中的文本内容
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
document.getElementById("btn").onclick = function () {
var text = document.getElementById("dv").innerHTML;
console.log(text);
};
</script>
</body>
四.innerText和textContent的区别
- 设置标签中的文本内容,应该使用textContent属性,谷歌,火狐支持,IE8不支持
- 设置标签中的文本内容,应该使用innerText属性,谷歌,火狐,IE8都支持
- 如果这个属性在浏览器中不支持,那么这个属性的类型是undefined
- 判断这个属性的类型 是不是undefined,就知道浏览器是否支持
1.兼容代码设置任意的标签中间的任意文本内容
<script>
function setInnerText(element, text) {
//判断浏览器是否支持这个属性
if (typeof element.textContent == "undefined") {//不支持
element.innerText = text;
} else {//支持这个属性
element.textContent = text;
}
};
</script>
2.兼容代码获取任意标签中间的文本内容
<script>
function getInnerText(element) {
if (typeof element.textContent == "undefined") {
return element.innerText;
} else {
return element.textContent;
}
};
</script>
五.textContent、innerText和innerHTML的区别
textContent、innerText的效果是一样的,所以这里我只用innerText举例
1.设置标签中的文本内容
innerText的效果
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
function my$(id) {
return document.getElementById(id);
};
</script>
<script>
my$("btn").onclick = function () {
my$("dv").innerText = "哈哈";//设置文本
my$("dv").innerText = "<p>这是一个p</p>";//设置html标签的代码
};
</script>
</body>
innerHTML的效果
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">这是一个div</div>
<script>
function my$(id) {
return document.getElementById(id);
};
</script>
<script>
my$("btn").onclick = function () {
my$("dv").innerHTML = "哈哈";
my$("dv").innerHTML = "<p>这是一个p</p>";//设置Html标签的
};
</script>
</body>
2.获取标签中的文本内容
innerText的效果
<body>
<input type="button" value="按钮" id="btn">
<div id="dv">
<p>这是一个p</p>
</div>
<script>
document.getElementById("btn").onclick = function () {
//可以获取标签中的文本内容
console.log(document.getElementById("dv").innerText);
};
</script>
</body>
innerHTML的效果
3.总结
- 如果使用innerText主要是设置文本的,设置标签内容,是没有标签的效果的
- innerHTML是可以设置文本内容
- innerHTML主要的作用是在标签中设置新的html标签内容,是有标签效果的
- 想要设置标签内容,使用innerHTML,想要设置文本内容,innerText或者textContent,或者innerHTML,推荐用innerHTML
- innerText可以获取标签中间的文本内容,但是标签中如果还有标签,那么最里面的标签的文本内容也能获取.---获取不到标签的,文本可以获取
- innerHTML才是真正的获取标签中间的所有内容
本篇博客来自于传智播客视频教程的总结以及笔记的整理,仅供学习交流,切勿用于商业用途
沃梦达教程
本文标题为:js中textContent、innerText和innerHTML的用法以及区别
基础教程推荐
猜你喜欢
- vue的 Mixins (混入) 2023-10-08
- 解决ajax的delete、put方法接收不到参数的问题方法 2023-02-23
- ECSHOP中实现ajax弹窗登录功能 2023-01-31
- 基于bootstrap的上传插件fileinput实现ajax异步上传功能(支持多文件上传预览拖拽) 2023-02-01
- 分页技术原理与实现之无刷新的Ajax分页技术(三) 2023-01-20
- 深入浅析Jsonp解决ajax跨域问题 2022-12-28
- 第7天:CSS入门 2022-11-04
- Vue+WebSocket实现在线聊天 2023-10-08
- 关于 css:WebKit (iPad) CSS3: 背景过渡闪烁 2022-09-21
- ExtJS 3.x DateField menuListeners 显示/隐藏 2022-09-15