2020-09-28

innerText、innerHTML、textContent

innerText:可以设置内容,但是不解析标签,不显示效果(谷歌、火狐、IE8都支持)
innerHTML:可以设置内容,解析标签,可以显示效果
textContent:可以设置内容(谷歌、火狐支持,IE8不支持)

<body>
	<input type="button" value="按钮" id="btn">
	<div>真好看</div>
	<script src="common.js" type="text/javascript" charset="utf-8"></script>
	<script type="text/javascript">
		mFun$("btn").onclick = function (){
			// var con = document.getElementsByTagName("div")[0].innerText = "真衰啊!";
			//原格式输出
			// var con = document.getElementsByTagName("div")[0].innerText = "<i>真衰啊!</i>";
	
			// var con = document.getElementsByTagName("div")[0].innerHTML = "真衰啊!";
			//可以解析 
			// var con = document.getElementsByTagName("div")[0].innerHTML = "<i>真衰啊!</i>";

			// var con = document.getElementsByTagName("div")[0].textContent = "真衰啊!";
			//原格式输出
			// var con = document.getElementsByTagName("div")[0].textContent = "<i>真衰啊!</i>";
		console.log(con);
		}
		//如果一个浏览器不支持指定属性,返回的是一个undefined
		//设置任意的标签的任意内容
		//element 元素\标签  text 要设置的内容
		function setInnerText(element,text){
			if(typeof element.textContent == "undefined"){
				return element.innerText = text;
			}else{
				return element.textContent = text;
			}
		}
		var div = document.getElementsByTagName("div")[0]
		 mFun$("btn").onclick = function (){
			 setInnerText(div,"随便");
		 }
		 
		//获取标签中任意内容
		function getInnerText(element){
			if(typeof element.textContent == "undefined"){
				return element.innerText;
			}else{
				return element.textContent;
			}
		} 
	</script>
</body>

自定义属性

HTML标签中不存在属性,需要自己定义的属性叫做自定义属性
设置自定义属性 setAttribute("设置的属性名","设置的属性值")
获取自定义属性 getAttribute('属性名')
移除自定义属性 removeAttribute移除属性[自定义/系统的]

自定义属性的设置与获取

<body>
	<ul id="u">
		<li>1号</li>
		<li>2号</li>
		<li>3号</li>
	</ul>
	<script src="common.js" type="text/javascript" charset="utf-8"></script>
	<script type="text/javascript">
		//1- 根据id为u的获取指定元素,获取该标签中所有的li
		var li = mFun$("u").getElementsByTagName("li");
		//2- 遍历所有li标签
		for(var i = 0;i < li.length;i++){
			//li[i].mv = "萝莉"+(i+1)+"号";//直接给dom对象没有给标签
			//设置每个li标签属性为 mv  值为"萝莉"+(i+1)+"号"
			li[i].setAttribute("mv","萝莉"+(i+1)+"号");
			//对每个li注册点击事件
			li[i].onclick = function(){
				//弹出获取的属性信息
				alert(this.getAttribute("mv"));
			}
		}
	</script>
</body>

移除自定义属性

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
			.c1{
				width: 200px;
				height: 200px;
				background-color: darkorange;
			}
		</style>
	</head>
	<body>
		<input type="button" value="按钮" id="btn">
		<div mv ="萝莉" class="c1"></div>
		<script src="common.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript">
			//removeAttribute 移除属性[自定义\系统的]
			mFun$("btn").onclick = function(){
				//document.getElementsByTagName("div")[0].removeAttribute("mv");
				//document.getElementsByTagName("div")[0].removeAttribute("class");
			}
		</script>
	</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值