ASCII码 ASCII码

JavaScript属性操作

发布于:2022-03-14 10:07:26  栏目:技术文档

一、属性的设置和获取1、属性的设置和获取主要有两种方式:`<!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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]); }; </script></head>

<body>

</body></html>运行结果: ![](https://img.php.cn/upload/image/622/249/295/1647169273710077.jpg) 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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]);

  1. // 区别
  2. // "."号只能取本身的属性,"[]"里面可以是变量,也可以是自身的属性
  3. var obj1={
  4. name:"jack",
  5. age:18
  6. };
  7. // 定义一个变量
  8. var a="name";
  9. console.log(obj2[a]);//等同于 console.log(obj2["name"]);
  10. // console.log(obj2.a) 错误的写法,.只能取自身的属性
  11. console.log(obj2.name);
  12. };
  13. </script>

</head>

<body>

</body></html>运行结果: ![](https://img.php.cn/upload/image/187/254/774/1647169308783332.jpg) 二、属性的删除 看下面的例子:<!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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 /* var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]);

  1. // 区别
  2. // "."号只能取本身的属性,"[]"里面可以是变量,也可以是自身的属性
  3. var obj1={
  4. name:"jack",
  5. age:18
  6. };
  7. // 定义一个变量
  8. var a="name";
  9. console.log(obj2[a]);//等同于 console.log(obj2["name"]);
  10. // console.log(obj2.a) 错误的写法,.只能取自身的属性
  11. console.log(obj2.name); */
  12. // 属性的删除
  13. var obj2={
  14. name:"jack",
  15. age:18,
  16. sex:"男",
  17. email:"747934521@qq.com"
  18. };
  19. // 通过.删除age属性
  20. delete obj2.age
  21. console.log(obj2);
  22. // 通过[]删除sex属性
  23. delete obj2["sex"];
  24. console.log(obj2);
  25. // 同样也可以通过变量删除
  26. var temp="email";
  27. delete obj2[temp];
  28. console.log(obj2);
  29. };
  30. </script>

</head>

<body>

</body></html>运行结果: ![](https://img.php.cn/upload/image/963/293/400/1647169343484068.jpg) 三、判断属性是否存在 1、使用in运算符。如果属性存在返回true,属性不存在返回false,看下面的例子:<!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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 /* var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]);

  1. // 区别
  2. // "."号只能取本身的属性,"[]"里面可以是变量,也可以是自身的属性
  3. var obj1={
  4. name:"jack",
  5. age:18
  6. };
  7. // 定义一个变量
  8. var a="name";
  9. console.log(obj2[a]);//等同于 console.log(obj2["name"]);
  10. // console.log(obj2.a) 错误的写法,.只能取自身的属性
  11. console.log(obj2.name); */
  12. // 属性的删除
  13. /* var obj2={
  14. name:"jack",
  15. age:18,
  16. sex:"男",
  17. email:"747934521@qq.com"
  18. };
  19. // 通过.删除age属性
  20. delete obj2.age
  21. console.log(obj2);
  22. // 通过[]删除sex属性
  23. delete obj2["sex"];
  24. console.log(obj2);
  25. // 同样也可以通过变量删除
  26. var temp="email";
  27. delete obj2[temp];
  28. console.log(obj2); */
  29. // 属性的检测
  30. // in 运算符 判断对象中的属性是否存在
  31. var obj3={
  32. name:"jack",
  33. age:18
  34. };
  35. console.log("name" in obj3);
  36. console.log("sex" in obj3);
  37. };
  38. </script>

</head>

<body>

</body></html>运行结果: ![](https://img.php.cn/upload/image/133/140/865/1647169378855923.jpg) 2、使用对象的hasOwnProperty()方法 同样,如果属性存在返回true,属性不存在返回false,看下面的例子:<!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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 /* var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]);

  1. // 区别
  2. // "."号只能取本身的属性,"[]"里面可以是变量,也可以是自身的属性
  3. var obj1={
  4. name:"jack",
  5. age:18
  6. };
  7. // 定义一个变量
  8. var a="name";
  9. console.log(obj2[a]);//等同于 console.log(obj2["name"]);
  10. // console.log(obj2.a) 错误的写法,.只能取自身的属性
  11. console.log(obj2.name); */
  12. // 属性的删除
  13. /* var obj2={
  14. name:"jack",
  15. age:18,
  16. sex:"男",
  17. email:"747934521@qq.com"
  18. };
  19. // 通过.删除age属性
  20. delete obj2.age
  21. console.log(obj2);
  22. // 通过[]删除sex属性
  23. delete obj2["sex"];
  24. console.log(obj2);
  25. // 同样也可以通过变量删除
  26. var temp="email";
  27. delete obj2[temp];
  28. console.log(obj2); */
  29. // 属性的检测
  30. // in 运算符 判断对象中的属性是否存在
  31. /* var obj3={
  32. name:"jack",
  33. age:18
  34. };
  35. console.log("name" in obj3);
  36. console.log("sex" in obj3); */
  37. // 使用对象的hasOwnProperty()方法
  38. var obj4={
  39. name:"jack",
  40. age:18
  41. };
  42. console.log(obj4.hasOwnProperty("name"));
  43. console.log(obj4.hasOwnProperty("sex"));
  44. };
  45. </script>

</head>

<body>

</body></html>`运行结果:注意:这里也可以使用变量的方式进行判断属性是否存在,例如:3、使用undefined判断

如果属性的值不等于undefined,则表示属性存在,返回true。如果属性的值等于undefined,则表示属性不存在,返回false。看下面的例子:`<!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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 /* var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]);

  1. // 区别
  2. // "."号只能取本身的属性,"[]"里面可以是变量,也可以是自身的属性
  3. var obj1={
  4. name:"jack",
  5. age:18
  6. };
  7. // 定义一个变量
  8. var a="name";
  9. console.log(obj2[a]);//等同于 console.log(obj2["name"]);
  10. // console.log(obj2.a) 错误的写法,.只能取自身的属性
  11. console.log(obj2.name); */
  12. // 属性的删除
  13. /* var obj2={
  14. name:"jack",
  15. age:18,
  16. sex:"男",
  17. email:"747934521@qq.com"
  18. };
  19. // 通过.删除age属性
  20. delete obj2.age
  21. console.log(obj2);
  22. // 通过[]删除sex属性
  23. delete obj2["sex"];
  24. console.log(obj2);
  25. // 同样也可以通过变量删除
  26. var temp="email";
  27. delete obj2[temp];
  28. console.log(obj2); */
  29. // 属性的检测
  30. // in 运算符 判断对象中的属性是否存在
  31. /* var obj3={
  32. name:"jack",
  33. age:18
  34. };
  35. console.log("name" in obj3);
  36. console.log("sex" in obj3); */
  37. // 使用对象的hasOwnProperty()方法
  38. /* var obj4={
  39. name:"jack",
  40. age:18
  41. };
  42. console.log(obj4.hasOwnProperty("name"));
  43. console.log(obj4.hasOwnProperty("sex"));
  44. // 使用变量的方式判断
  45. var temp="name";
  46. console.log(obj4.hasOwnProperty(temp));
  47. var temp1="email";
  48. console.log(obj4.hasOwnProperty(temp1)); */
  49. // 判断属性的值是否不等于undefined
  50. var obj5={
  51. name:"jack",
  52. age:18
  53. };
  54. console.log(obj5.name!=undefined);
  55. console.log(obj5.sex!=undefined);
  56. };
  57. </script>

</head>

<body>

</body></html>运行结果: ![](https://img.php.cn/upload/image/899/405/651/1647169486549012.jpg) 注意:如果属性的值正好是undefined,那么这时就不能用这种判断了,看下面的例子: ![](https://img.php.cn/upload/image/192/842/257/1647169506322232.jpg) 四、属性的遍历 1、使用for...in遍历属性<!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>JavaScript中属性的基本操作</title> <script> window.onload=function(){ // 属性的设置或获取 /* var obj={}; // 通过”.”号的方式设置属性 obj.name=”tom”; // 通过”[]”的方式设置属性 obj[“age”]=20; // 通过”.”号的方式获取属性 console.log(“姓名:”+obj.name); // 通过”[]”的方式获取属性 console.log(“年龄:”+obj[“age”]);

  1. // 区别
  2. // "."号只能取本身的属性,"[]"里面可以是变量,也可以是自身的属性
  3. var obj1={
  4. name:"jack",
  5. age:18
  6. };
  7. // 定义一个变量
  8. var a="name";
  9. console.log(obj2[a]);//等同于 console.log(obj2["name"]);
  10. // console.log(obj2.a) 错误的写法,.只能取自身的属性
  11. console.log(obj2.name); */
  12. // 属性的删除
  13. /* var obj2={
  14. name:"jack",
  15. age:18,
  16. sex:"男",
  17. email:"747934521@qq.com"
  18. };
  19. // 通过.删除age属性
  20. delete obj2.age
  21. console.log(obj2);
  22. // 通过[]删除sex属性
  23. delete obj2["sex"];
  24. console.log(obj2);
  25. // 同样也可以通过变量删除
  26. var temp="email";
  27. delete obj2[temp];
  28. console.log(obj2); */
  29. // 属性的检测
  30. // in 运算符 判断对象中的属性是否存在
  31. /* var obj3={
  32. name:"jack",
  33. age:18
  34. };
  35. console.log("name" in obj3);
  36. console.log("sex" in obj3); */
  37. // 使用对象的hasOwnProperty()方法
  38. /* var obj4={
  39. name:"jack",
  40. age:18
  41. };
  42. console.log(obj4.hasOwnProperty("name"));
  43. console.log(obj4.hasOwnProperty("sex"));
  44. // 使用变量的方式判断
  45. var temp="name";
  46. console.log(obj4.hasOwnProperty(temp));
  47. var temp1="email";
  48. console.log(obj4.hasOwnProperty(temp1)); */
  49. // 判断属性的值是否不等于undefined
  50. /* var obj5={
  51. name:"jack",
  52. age:18
  53. };
  54. console.log(obj5.name!=undefined);
  55. console.log(obj5.sex!=undefined);
  56. //
  57. var obj6={
  58. name:undefined,
  59. age:18
  60. };
  61. console.log(obj6.name!=undefined); */
  62. // 属性的遍历
  63. // for...in 遍历对象的属性
  64. var obj7={
  65. a:"1",
  66. b:"2",
  67. c:"3"
  68. };
  69. for(var v in obj7){
  70. // 输出obj7的属性
  71. console.log(v);
  72. // 输出属性对应的值
  73. console.log(obj7[v]);
  74. }
  75. };
  76. </script>

</head>

<body>

</body></html>`运行结果:for..in同样也可以遍历数组:五、序列化1、JSON.stringify()将对象序列化成JSON格式的字符串,前端传递数据给后台的时候使用,例如:2、JSON.parse()将JSON格式的字符串转换成对象,后台把数据传递到前端的时候使用,例如:

相关推荐
阅读 +