前端(DOM 、BOM 和 事件 )

目录

前言

一、DOM文档流

           1.什么是DOM文档流

           2.  DOM = Document Object Model   DOM文档流

           3.关于DOM的小实例 

           4.DOM 改进

二、BOM

 1.window对象

          2.计时器相关 

          3. 改进BOM

          window子对象:

三、事件

1.精点

2.级联 (经常用到)

四、 实例应用(小练习)

总结



前言

        js包含ECMAScript、DOM、BOM。BOM(browser object model)浏览器对象模型,使js获得了操纵浏览器的能力。DOM(document object model)文档对象模型,使js获得了可以获取html内元素的能力。








一、DOM文档流

1.什么是DOM文档流

 DOM(文档对象模型)简单理解就是编写的html页面所有内容构成的树形结构。

根据 W3C 的 HTML DOM 标准,HTML 文档中的所有内容都是节点:

  •  整个文档是一个文档节点。
  •  每个 HTML 元素是元素节点。
  •  HTML 元素内的文本是文本节点。
  •  每个 HTML 属性是属性节点。
  •  注释是注释节点。

  







2.  DOM = Document Object Model   DOM文档流

       dom对象 = 把标签封装成的对象
        document对象是js内置提供的对象(html文档对应的dom对象)
        Dom操作 = 可以用来处理页面文档内容的

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>DMO</title>
		<script type="text/javascript">
			function tets(){
	
				console.log(document);
				console.log(a1)
				var a1=document.getElementById("id_a") // 通过id属性 来获取元素或标签(返回对拥有指定 id 的第一个对象的引用。)
				var b1=document.getElementsByClassName("clsaa_a") // 通过class属性来获取元素(	返回文档中所有指定类名的元素集合,作为 NodeList 对象。)
				var c1=document.getElementsByName("name_a")// 通过name属性来获取元素(	返回带有指定名称的对象集合。)
				var d1=document.getElementsByTagName("tag_a")// 通过tagname来获取元素	(返回带有指定标签名的对象集合。)
				
			}
			test()
		</script>
	</head>
	<body>
		DOM = Document Object Model   DOM文档流
		dom对象 = 把标签封装成的对象
		document对象是js内置提供的对象(html文档对应的dom对象)
		Dom操作 = 可以用来处理页面文档内容的
		innerText 				重点	从起始位置到终止位置的内容,但它去除Html标签
		innerHTML 				重点	从对象的起始位置到终止位置的全部内容,包括Html标签。
		getElementById 			重点	通过id来获取元素或标签
		getElementsByClassName 	重点	通过class来获取元素或标签
		getElementsByName 		重点	通过name来获取元素或标签
		getElementsByTagName 	重点	通过标签name来获取元素或标签
		value 					重点	取值和赋值
		
		<div id="id_a" class="class_a" name="name_a"> bbb </div> <!-- 先定义后使用 -->
		<button onclick="test2()"> AAA</button> <!-- 静态 事件绑定 =事件监听   -->
		
		
		<script type="text/javascript">
			function test2(){// 事件绑定 = 事件监听
				var dom3 =document.getElementById("id_a3");
				dom3.onclick = function(){alert("T-T")} // 动态事件绑定 js
				dom3.onclick = null; // 取消事件绑定
				dom3.addEventListener("click",function(){});// 标准使用格式 添加事件监听
				dom3.removeEventListener("click") // 标准 去除事件监听
			}
			
			function test1(){// 如何来操作
				var dom1 =document.getElementById("id_a1");
				dom1.innerText="asdasd"// 将内部文本调整为asdasd    必须要会
				dom1.innerHTML = "<input type='text' value='asdasd' />"  /// 必须要会
				Console.log(dom1.innerHTML) //取出文本内容必须要会
				// innerText(只能输出文本内容)
				// innerHTML(可以解析标签)
				
				dom1.value = "改变内容"; // 改变标签的内容  复合属性  取值  赋值
				dom1.style.backgroundColor="salmon"; // 改变标签背景颜色
			}
		
		
			// function test(){ // 如何来找
			// 	// 先定义后使用  放在25行之后 才能得到
			// 	var a1=document.getElementById("id_a") // 通过id属性 来获去元素或标签
			// 	console.log(document);
			// 	console.log(a1)
			// 	var b1=document.getElementsByClassName("clsaa_a") // 得到数组
			// 	var c1=document.getElementsByName("name_a") // 得到数组
			// 	var d1=document.getElementsByTagName("tag_a") // 得到数组
				
			// }
			// test()
		</script>
		
	</body>
</html>

重点: 

        innerText                              重点    从起始位置到终止位置的内容,但它去除Html标签
        innerHTML                           重点    从对象的起始位置到终止位置的全部内容,包括Html标签。
        getElementById                   重点    通过id来获取元素或标签
        getElementsByClassName  重点    通过class来获取元素或标签
        getElementsByName           重点    通过name来获取元素或标签
        getElementsByTagName     重点    通过标签name来获取元素或标签
        value                                    重点    取值和赋值 


3.关于DOM的小实例 

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			var name = "aaa";
			var obj = {
				name : "bbb",
				getName:function(){ // object 
					Console.log(this.name); // bbb
					// fun =function(){ // 2 (分开写)
					// 	console.log(this.name); // 2 (分开写)
					// } // 2 (分开写)
					// return fun;  // 2 (分开写)
					 return function(){ 1(合起来)   // 没有使用var是全局方法    window
					 	console.log(this.name); 1(合起来)
					 } 1(合起来)
				}
			};
			obj.getName()(); // 1、2  // 第一个 getName 对象  第二个 return 对象
			// (function(){  // 1、3
			// 			console.log(this.name); // 1、3
			// })() // 1、3
		</script>
	</head>
	<body>
	</body>
</html>


4.DOM 改进:

  dom使js拥有了操纵html标签的能力。浏览器在创建页面的时候,会按照文档,元素,文本,属性,注释分类,形成了以html为根节点的树,那么这个树就叫做HTML DOM树。js可以通过dom获得标签进行操作,使js拥有了动态改变页面中所有元素,以及它们的属性和css样式能力。

  1 查找标签:

    1 直接查找:

document.getElementByIddocument.getElementById('d1')根据id获取一个标签
document.getElementBysClassNamedocument.getElementBysClassName('c1')根据class获取一组标签
document.getElementByTagNamedocument.getElementByTagName('div')根据标签名获取标签合集

    2 间接查找:

parentElement

父节点标签
children所有子标签
firstElementChild第一个子标签元素
lastElementChild最后一个子标签元素
nextElementChild下一个兄弟标签元素
previousElementSibling上一个兄弟标签元素

      间接查找思路寻找一个中间标签,然后通过中间标签再去找想要找的标签

1

2

var a1Ele=document.getElementById("a1");

a1Ele.parentElement

  2 操纵节点(根据dom树来分): 

    1 创建元素节点:

1

2

3

4

5

6

7

var imgEle=document.createElement("img");

找到想要加入的元素

var d3Ele=document.getElementById("d3");

在d3Ele内加入imgEle标签

d3Ele.appendChild(imgEle)

设置imgEle的属性

imgEle.src=”图片地址”

    2 添加元素节点:

      1 追加一个子节点,相当于python中列表的append方法:

1

2

3

var imgEle=document.createElement("img");

var d3Ele=document.getElementById("d3");

d3Ele.appendChild(imgEle)

      2  在某个元素节点之前插入一个元素节点:

1

2

3

4

5

6

7

8

9

10

11

先查找想要插入标签的父标签

 var dEle=document.getElementById("cc1");

超找想要插入标签

  var dEle1=document.getElementById("d1");

创建想要被插入的标签

var spanEle1=document.createElement("span");

    插入

dEle.insertBefore(spanEle1,dEle1);

   给被插入标签赋值文本属性

spanEle1.innerText='span---123';

   Cc1 和 d1 为包含关系  使用insertBefor,在确定父标签和目标标签时最好使用id

    3 删除元素节点:

1

2

3

var dEle=document.getElementById("cc1");

Var sonEle=dEle.firstElementChild

dEle.removeChild(sonEle)

    4 替换元素节点:

1

2

在Ele内部用newnode替换oldnode

 Ele.replaceChild(newnode,oldnode)

    5 操纵属性节点:

setAttribute()d1Ele.setAttribute("age","18")设置属性
getAttribute()d1Ele.getAttribute("age")获取属性值
removeAttribute()d1Ele.removeAttribute('age')删除属性

    6 操纵文本节点;

      1 获取文本节点的值;

1

2

3

4

5

6

var divEle = document.getElementById("d1");

获得标签以及子标签的全部内容(标签+文本内容)

divEle.innerHTML

获得标签以及子标签文本内容

divEle.innerText

      2 变更文本节点的值:

1

2

3

4

5

6

var divEle = document.getElementById("d1");

divEle文本中赋值,此时写入的字符串标签会被浏览器解释成标签来执行

divEle.innerHTML="<div>innerHTML</div>"

给innerText赋值

divEle.innerText="1111"

     7 获取值操作

 

var selEle=document.getElementById('s1');

select

selEle.value

"021"

var u1Ele=document.getElementById('u1');

Input typle=’text’

u1Ele.value

ddd

var u1Ele=document.getElementByname(‘sex’)

Input type=’radio’

 使用jquery获取值

var tEle=document.getElementById('t1');

Input type=‘’textarea‘’

tEle.values

ssss

        同样重新赋值可以采取一下方式

        selEle.value=1

      8 class节点操作:

className

Ele.className

获取标签下所有的class属性值

classList.remove(cls)

Ele.classList.remove(cls)

删除指定类

classList.add(cls)

Ele.classList.add(cls)

添加类

classList.contains(cls)

Ele. classList.contains(cls)

存在返回true否则返回false

classList.toggle(cls)

Ele.classList.toggle(cls)

存在就删除,否则添加 

        利用toggle操纵class,实现开关灯:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

<!DOCTYPE html>

<html lang="zh-CN">

<head>

    <meta charset="UTF-8">

    <title>class相关操作   开关灯</title>

    <style>

        .c1{

            height: 200px;

            width: 200px;

            border-radius: 50%;

            background-color: black;

        }

        .c2{

            background-color: red;

        }

        /*.c3{*/

        /*    background-color: #e5ffad;*/

        /*}*/

    </style>

</head>

<body>

<div class="c1 c2 c3" onclick="chan(this);">dfgdfgdf</div>

<div class="c1 c2 c3" >dfgdfgdf2222</div>

<div class="c1 c2 c3" >dfgdfgdf3333</div>

<div class="c1 c2 c3" >dfgdfgdf444444</div>

</body>

<script>

function chan(ths) {

    ths.classList.toggle('c2');

};

</script>

<script>

    var divEle=document.getElementsByTagName('div');

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

        //遍历返回的列表,给每个标签绑定一个事件

        divEle[i].onclick=function () {

            this.classList.toggle('c2')

        }

    }

</script>

</html>

        修改指定标签的class属性;

1

2

3

4

对于没有中横线的css属性,一般直接使用style就行

有中横线的css属性,中横线后的第一个字母大写

var divEles=document.getElementsByTagName('div')

divEles[0].style.backgroundColor="blue"


二、BOM

 1.window对象:

  window对象是客户端javascript的最高层对象之一,所有的浏览器都支持window对象,也可以粗暴的认为打开一个浏览器窗口或页面就是生成了一个window对象。所有js全局对象,函数以及变量均为windows的对象的组成元素。全局变量是window对象的属性,全局函数是window对象的方法,可以想想成python中的类,类中有静态属性和动态属性。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>bom</title>
	</head>
	<body>
		BOM = browser object model
		<script type="text/javascript">
			// 1- window(浏览器) // 最核心 最大  可省略
			// 2- window.location(浏览器的地址栏)  重要
			// 3- window.history (在浏览器窗口中)访问过的 URL。
			// 4- window.navigator  导航 包含有关浏览器的信息。
			// 5- window.screen	  包含有关客户端显示屏幕的信息
			function test1(){
				window.alert("aaa")// 信息提示框
				confirm();// = window.confirm();  选择提示框 (是/否  确认/取消)
				var res = confirm("bbb");
				if(res){}
				var res1 = prompt("AA","BB");// 输入提示框  第二个"BB" 默认null
				window.open();// ifname       window 可省略
				var url = location.href;
				alert(url)
				location.href="http://www.baidu.com" // 页面跳转 (动态跳转) 
				location.href=location.href;// 重新加载当前网址
				location.reload(); // 等价于22行
				// location.protocol
				// location.hostname
				// location.port
				// location.pathname
				// history.back()// 回退
				// history.forward()// 前进
				// history.go(1)// 后一页
				// screen.height// 屏幕高度
				// screen.width// 屏幕宽度
				
				
				// document.cookie // 临时数据
				// localStorage // 本地存储数据
				// sessionStorage	// 会话存储数据
			}
		</script>
	</body>
</html>

2.计时器相关 

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<div id="id_a"></div>
		<button onclick="start()">start</button>
		<button onclick="stop()">stop</button>
		<script type="text/javascript">
			// function setTime(){ // 定时任务的使用(定义在内部)
			// 	setInterval(function(){
			// 		var dom1 = document.getElementById("id_a");
			// 		dom1.innerHTML =new Date().toLocaleString()
			// 		console.log(new Date().toLocaleString());
			// 	},1000); //每隔1000秒回调一次
			// }
			function setTime(){// 定时任务 (定义在外部 )
				var dom1 = document.getElementById("id_a");
				dom1.innerHTML =new Date().toLocaleString()
				
			}
			var x;
			function start(){
				x = setInterval(setTime,1000); // 设置时间间隔
				// x = setTimeout(setTime,1000); // 设置时间延迟
			}
			
			function stop(){ // 关闭定时器
				clearInterval(x) // 清除时间间隔
				// clearTimeout(x) // 清除时间延迟
			}
			
			
			// time计时器
			window.setInterval() // 设置时间间隔   固定时间执行
			window.clearInterval()// 清除时间间隔
			window.setTimeout()	// 设置时间延迟	  指定时间执行一次
			window.clearTimeout() // 清除时间延迟
			
		</script>
	</body>
</html>

3. 改进BOM

 window对象:

  window对象是客户端javascript的最高层对象之一,所有的浏览器都支持window对象,也可以粗暴的认为打开一个浏览器窗口或页面就是生成了一个window对象。所有js全局对象,函数以及变量均为windows的对象的组成元素。全局变量是window对象的属性,全局函数是window对象的方法,可以想想成python中的类,类中有静态属性和动态属性。

window.innerHeight浏览器窗口的内部高度
window.innerWidth浏览器窗口的内部宽度
window.open()打开新窗口
window.close()关闭当前窗口

  window子对象:

location.href获取当前页面url
location.href='url'跳转url
location.reload()刷新

  

  弹出框:

alert()警告框
confirm()确认框 返回true和false
prompt()提示框 提示用户输入某个值,然后点击确认或取消按钮才能操作,如果点击确认,那么返回值就是填写的值,如果取消则为null

  计时相关:

    js中我们可以设定一个时间间隔来执行代码,而不是在函数在调用之后立即执行,我们称为计时时间

setTimeout()

var t=setTimeout(“alert(123)”,1000) 

等待1秒后执行,并且有返回值相当于计时事件的id
setInterval()

var t=setTimeout(“alert(123)”,5000) 

每5秒执行一次函数,并且有返回值相当于计时事件的id
clearTimeout()

clearTimeout(t)

取消setTimeout设置
clearInterval()clearInterval(t)参数必须是setInterval的返回值

    以下是定时器的例子:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

<!DOCTYPE html>

<html lang="zh-CN">

<head>

    <meta charset="UTF-8">

    <title>计时器</title>

</head>

<body>

<label for="i1">显示日期</label>

<input type="text" id="i1">

<input type="button" value="开始" id="start_button">

<input type="button" value="结束" id="stop_button">

<script>

    var t;

    var startEle=document.getElementById("start_button");

    var stopEle=document.getElementById("stop_button");

   function foo_time() {

       var new_time=new Date();

       var str_time=new_time.toLocaleString();

        var i1Ele=document.getElementById("i1");

       i1Ele.value=str_time;

   };

   startEle.onclick=function () {

       if (t===undefined) {

             foo_time();

      t= setInterval(foo_time,1000);

       }

   };

   stopEle.onclick=function () {

       clearTimeout(t);

       console.log('cleartimeout',t);

       t=undefined;

   }

</script>

</body>

</html>


三、事件

1.精点

                 onclick 单机  ondblclick 双击 
                 onfocus 获得焦点  onblur 失去焦点 (鼠标所在位置) 
                 onchange  一般在select标签中
                 onchange  onreset 

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>事件</title>
	</head>
	<body>
		<!-- onclick 单机  ondblclick 双击 -->
		<!-- onfocus 获得焦点  onblur 失去焦点 (鼠标所在位置) -->
		<!-- onchange  一般在select标签中-->
		<!-- onchange  onreset -->
		
		<!-- 静态事件绑定 -->
		<!-- 动态事件绑定 -->
		
		<form onsubmit="test()" onreset="test()">
			<input type="submit"/>
			<input  type="reset"/>
		</form>
		
		<textarea onselect="test()" ></textarea>
		
		
		
		<select> <!-- 重要   级联(选定省 指定对应的市) -->
			<option onchange ="test()">aa</option>
			<option onchange ="test()">bb</option>
			<option onchange ="test()">cc</option>
		</select>
		<input type="text" onfocus="test()" />
		<script type="text/javascript">
			function test(){
				// alert(123)  
				var dom1 = document.getElementById("aa")
				var val  = dom1.value;
				var num = new Number
				
				
			}
		</script>
	</body>
</html>

2.级联 (经常用到)

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
//省份的下拉菜单
 <select name="" id="sheng">
     <option value="0">-----请选择省-----</option>
     <option value="1">四川省</option>
     <option value="2">云南省</option>
     <option value="3">贵州省</option>
 </select>//城市的下拉菜单
<select name="" id="city">
    <option value="0">-----请选择市-----</option>
</select>
</body>
</html>
<script>
//获得省份对象
let shengObj=document.getElementById("sheng");
//获得城市对象
let cityObj=document.getElementById("city");
//给省份的下拉菜单绑定一个change事件
shengObj.onchange=()=>{
    if(shengObj.value==0){
        cityObj.innerHTML="<option value='0'>-----请选择城市------</option>";
    }else if(shengObj.value==1){
        cityObj.innerHTML="<option value='1'>成都市</option><option value='2'>绵阳市 </option><option value='3'>德阳市</option>";
    }else if(shengObj.value==2){
        cityObj.innerHTML="<option value='1'>昆明市</option><option value='2'>玉溪市    </option><option value='3'>大理市</option>";
    }else{
        cityObj.innerHTML="<option value='1'>遵义市</option><option value='2'>贵阳市</option><option value='3'>赤水市</option>";

     }
}


</script>

效果: 

四、 实例应用(小练习)

代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		
		<div id="">
			记录列表 <br><br>
			姓名<input type="text" /> 年龄 <input type="text" /> 
			<button onclick="testAdd()">添加</button><br><br>
			姓名<input type="text" />
			<button onclick="testSel()">搜索</button><br><br>
			<table style="border: 1px solid black; width: 600px;">
				<thead>
					<tr>
						<td>ID</td>
						<td>姓名</td>
						<td>年龄<td>
						<td>操作</td>
					</tr>
				</thead>	
				<tbody id='tbody'></tbody>
			</table>
		</div>
		<script type="text/javascript">
			// 1- 获取标签内容
			// 2- 将获得的内容整合成 tr + td
			// 3- 写回到网页当中(tabale)
			
			var inputs = document.getElementsByTagName("input");
			var ids = 1;
			// function testAdd1(){
			// 	var name = inputs[0].value;
			// 	var age = inputs[1].value;
			// 	var oTr = document.createElement("tr");// <tr>
			// 	var oTd = document.createElement("td");// <td>
			// 	oTd.innerHTML = ids++;
			// 	oTr.appendChild(oTd);
			// 	var oTd = document.createElement("td");// <td>
			// 	oTd.innerHTML = name;
			// 	oTr.appendChild(oTd);
			// 	var oTd = document.createElement("td");// <td>
			// 	oTd.innerHTML = age;
			// 	oTr.appendChild(oTd);
			// 	var oTd = document.createElement("td");// <td>
			// 	oTd.innerHTML = "<a href='javascript:'onclick = 'testDel(this)'> 删除</a>
			// 			+	"&nbsp;<a href='javascript:' onclick = ''> 修改</a>";
			// 	oTr.appendChild(oTd);
			// 	document.getElementById("tbody").appendChild(oTr);
			// }
			function testAdd(){ // 添加
				var name = inputs[0].value;
				var age = inputs[1].value;
					// <tr><td></td><td></td><td></td><td></td></tr>  字符串拼接
				var html = ""
					+"<tr>"
					+	"<td>" + (ids++) + "</td>"
					+	"<td>" + name + "</td>"
					+	"<td>" + age + "</td>"
					+	"<td>" 
					+		"<a href='javascript:'onclick = 'testDel(this)'> 删除</a>&nbsp"
					+		"&nbsp;<a href='javascript:' onclick = 'testUpd(this)'> 修改</a>"
					+ 	"</td>"
					+"</tr>";
					// console.log(html)
				var tbody = document.getElementById("tbody");
				tbody.innerHTML += html;
			}
			
			function testDel(obj){ // 删除			// removeChild
				if(confirm("是否删除该行记录?")){
					var otr = obj.parentNode.parentNode;
					document.getElementById("tbody").removeChild(otr);
				}
			}
			
			function testUpd(obj){ //修改
				// console.log(obj)
				var td_this = obj.parentNode;
				var td_age = td_this.previousSibling; // id唯一标识  //前一个
				var td_name = td_age.previousSibling;
				var td_id = td_name.previousSibling.innerHTML;
				
				td_age.innerHTML = "<input type='text' id='tAge"+td_id+"' value ='"+td_age.innerHTML+"' />";
				td_name.innerHTML = "<input type='text' id='tName"+td_id+"' value='"+td_name.innerHTML+"' />";
				td_this.innerHTML = "<a href='javascript:'>保存</a>"
				td_this.getElementsByTagName('a')[0].onclick=function(){
					td_age.innerHTML = document.getElementById('tAge' + td_id).value;
					td_name.innerHTML = document.getElementById('tName'+td_id).value;
					td_this.innerHTML = "<a href='javascript:' onclick='testDel(this)'>删除</a>"
					+      "&nbsp;&nbsp;<a href='javascript:' onclick='testUpd(this)'>修改</a>";
				}
			}
	
			function testSel(){
				var rows = document.getElementsByTagName("tr");
				var len = rows.length;
				for(var i = 1;i < len;i++){
					rows[i].removeAttribute("style");
				}
				var name = inputs[2].value;
				if(name == '')
					return;
				for(var i = 1;i < len;i++){
					var td_name = rows[i].cells[1].innerHTML;
					if(td_name.indexOf(name) > -1)
						rows[i].style.backgroundColor = 'yellow'
				}
			}
		</script>
	</body>
	
</html>

展示: 

 







总结

        文档流是另一个概念,流实际上就是浏览器在页面上摆放Html元素所用的方法,大多数元素默认在文档流中。浏览器从Html文件最上面开始,从上到下沿着元素流逐个显示所遇到的各个元素。即:元素按HTML中编写的先后顺序,上下左右堆叠排列。其中块级元素前后换行,内联元素前后不换行。

        If not now, when? If not me, who? “时不我待,舍我其谁。”

        又是愉快的一天,加油!

    

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值