Bootstrap

初识JavaScript (十八)

1 函数对象的方法-call-apply-bind

重点:

this:关键字:代表了当前对象。
a:在事件使用。代表了当前正在触发执行事件函数的元素对象。
b:全局定义的函数中,或者全局作用域下的this代表了当前window对象。
如下的的代码中,两个对象的属性和功能都是不共享的,属性不共享是我们希望的,如果功能一样其实可以共享,实现内存的节约。
如何让一个对象的功能共享给其他对象。
实现的思路:让某一个对象的功能借用给其他的对象,通过隐式修改功能内的this 来实现方法的借用。
函数对象的三个方法的介绍:call、apply、bind
1:使用call 方法实现 方法的借用。
语法: 函数对象.call(受借者,方法的剩余的参数…)
受借者: 借用函数对象的对象。
返回:是函数对象的返回值。
2: 使用apply 方法实现方法的借用。
语法: 函数对象。apply(受借者,[方法其他的参数]);
和call方法的区别就是,第二个参数的实参要放到一个数组中。
返回:是函数对象的返回值。
3:使用bind,可以实现以某一个函数对象为原型,生成一个新的函数对象,该函数对象中的this可以指定。
语法: 函数对象.bind(指定的this对象)
返回:返回一个新的函数。这个函数是实参对象绑定个函数。直接调用返回的函数对象。
总结:
1:call、apply、bind、三个函数是js函数对象内置的函数。
2:三个函数的目的都是为了扩展现有函数的功能,可以将现有函数的功能扩展到其他的对象上去。
3:call、apply 两个方法是借用方法,不会产生新的对象。bind会产生的新的函数对象。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<script>
  var sun = {
      name: "孙宇航",
      age: 21,
      hobbies: ["迟到", "学习", "游戏"],
      score: 80,
      /*study: function () {
          //每次调用study方法,都会导致对象的分数自增一。
          console.log (`${this.name}努力学习,成绩从${this.score}提升到了${++this.score}`);
      }*/
  };
  // sun.study ();
  var dan = {
      name: "张梦丹",
      age: 17,
      hobbies: ["读盗墓笔记","歌曲"],
      score:85,
      study: function () {
          //每次调用study方法,都会导致对象的分数自增一。
          console.log (`${this.name}努力学习,成绩从${this.score}提升到了${++this.score}`);
      },
      max:function (num1,num2) {
          return num1 > num2 ? num1 : num2;
      }
  };
  dan.study();

  //两个功能一模一样,是否是同一个对象呢?
  console.log (sun.study === dan.study);

  //call 实现方法的借用调用。
  dan.study.call(sun);
  var max = dan.max.call(sun,1,6);
  console.log (max);

  dan.study.apply(sun);
  console.log (dan.max.apply(sun,[1,8]))

  //bind 生成新的函数。
  var newStudy = dan.study.bind(sun);
  console.log (newStudy);
  newStudy();
  var newMax = dan.max.bind(sun);
  console.log (newMax(1,9))

</script>
</body>
</html>

2 void在超链接中的应用

需求:单价超链接,执行一个函数。
上述的练习:即使href超链接是空的内容,点击的时候也会刷新页面。

void:在js中是一个关键字,在其他的语言中通常是用来定义函数的。代表函数没有返回值。
void是空的意思。在a标签中使用 void 可以实现阻断a标签的默认行为
语法:javascript : void(0)

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
</head>
<body>
<a href="" onclick="test()">点我一下</a>
<!--当点击超链接的时候,执行js代码 void(0) 意味着什么都不做。-->
<a href="javascript:void(0)" onclick="test()">再点我一下</a>
<script>
 function test() {
     console.log ("hello");
 }
</script>
</body>
</html>

3 引入正则表达式

练习:页面中定义个输入框,接收一个qq号。检测qq号是否合法。
qq号的合法的要求:
1:纯数字
2:个数:[5,13]
3: 第一个不能是0

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
QQ<input type="text"><span style="color: red"></span>
<script>
  var qqInput = document.querySelector ("input");
  var span = document.querySelector ("span");
  qqInput.oninput = function () {
      var result = checkeRegexpQQ (qqInput.value);
      span.innerHTML = result ? "√" : "×";
  };

  //检测qq是否合法的方法
  function checkeQQ(qqStr) {
      const MIN_LEN = 5;
      const MAX_LEN = 13;
      const LEN = qqStr.length;
      //长度
      if (LEN < MIN_LEN)
          return false;
      if (LEN > MAX_LEN)
          return false;
      //判断纯数字
      for (let i = 0; i < LEN; i++) {
          var ch = qqStr.charAt (i);
          if (ch < "0")
              return false;
          if (ch > "9")
              return false;
      }
      //第一个数字不是0
      if (qqStr.charAt (0) == "0")
          return false;

      return true;
  }
  
  function checkeRegexpQQ(qqStr) {
      var reg = /^[1-9]\d{4,12}$/;
      return reg.test(qqStr);
  }
</script>
</body>
</html>

4 正则的介绍

正则表达式:Regular Expression。
或者成为:规范式。规则式。
js:RegExp
java:regex
概念:正则表达式是一个具有特殊含义的字符的序列。

正则的作用:
1:用来做字符串的整串的匹配的。
用来检测字符串是否满足正则表达式所规定的格式的。
2:子串的查找,在一个字符串中,用来查找字符串中满足某种正则规定的格式的子串。

如何学习:
学习正则表达式中的哪些特殊符号的含义。

5 正则的创建

正则表达式对象的创建:
1:var 正则变量 = /正则的内容/[修饰符];
2: 构造函数。
var 正则变量 = new RegExp(“正则的内容”,“修饰符”);
3:正则表达式的实例方法。test(测试的字符串)
语法: 正则对象.test(str)
测试 str 是否满足 当前正则对象规定的模式的。如果满足,返回true,否则返回false。

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>Title</title>
</head>
<body>
<script>
   //1
   var reg = /^a+$/i;//1-n个a
   console.log (reg.test(""));//false
   console.log (reg.test("a"));//true
   console.log (reg.test("aaaaaaaaaaAAAaaaaaaaaaaaa"));//true
   console.log (reg.test("ab"));//false

   //2
   var reg1 = new RegExp("^\\w*$","i");
   console.log (reg1.test(""));//true
   console.log (reg1.test("ABCDaaa"));//true
   console.log (reg1.test("你好"));//false
</script>
</body>
</html>

6 正则的构成

正则表达式的构成:
1:普通字符:a-z A-Z 0-9 _
2: 特殊字符:具有特殊意义的符号(元字符)。

1:定位符:用来规定字符串中位置的符号。
^: 规定以xx开头 ^在正则的起始位置,约定了以它后面的内容开始。
$: 规定以xx结尾 在 正 则 的 结 尾 位 置 , 约 定 了 以 它 前 面 的 内 容 结 束 。 注 意 : 如 果 希 望 是 整 串 的 匹 配 那 么 必 须 以 开 头 , 以 在正则的结尾位置,约定了以它前面的内容结束。 注意:如果希望是整串的匹配那么必须以^开头,以 结尾。
如果不添加上述的约束,就是子串的匹配了。
如果想进行子串的查找,就不要添加开头和结尾的特殊符号了。
2:数量符:是用来约束数量符前面的字符的个数的。
? : 代表了前面的字符出现 0-1次。
* : 代表前面的字符出现0-n次。
+ : 代表前面的字符出现1-n次。
{m,n}:代表前面的字符出现m-n次。m和n都包含。
{n}:代表前面的字符出现n次。
{n,}:代表前面的字符出现 n - Infinty 次
3:字符集:[] 中括号中的字符的集合中的某一个字符。
[yangheli]:中括号中的字符中的某一个字符。
[a-z]: 26个小写字符集中的某一个字符。
[A-Z]: 26个大写字符集中的某一个字符。
[a-zA-Z]:52个大小写字符集中的某一个字符。
[0-9]:10个阿拉伯数字的集合中的一个字符。
[a-zA-Z0-9_]:标识符的所有的字符的集合中的某一个字符。
[^a-z]:取反的符号。除了小写字符之外的所有的其他的字符的集合中的一个。

4:预定义字符集:
\d:等价于[0-9]
\D: 等价于[^0-9]
\w: 等价于[a-zA-Z0-9_]
\W:等价于[^a-zA-Z0-9_]
\s: 等价于空白字符的集合
\S: 对\s 取反。所有的非空白字符的集合。

5: 特殊符号
/ :具有特殊意义的符号。如果希望在正则中表示一个/ 符号。必须进行转义。
/: 代表了符号 /

点: . : 在正则中的意思是任意字符。
如果希望去匹配一个点字符,而不是任意字符,那么需要转义。
. 代表了 点字符。

中文字符的区间[\u4e00-\u9fa5]

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    //定位符
    var reg = /^\d+z$/;
    console.log (reg.test("123"));
    console.log (reg.test("112323z"));
    //数量词
    var reg = /^ab?$/;
    console.log (reg.test("a"));//true
    console.log (reg.test("ab"));//true
    console.log (reg.test("abb"));//false
    console.log ("----------------");
    var reg = /^ab*$/;
    console.log (reg.test("a"));//true
    console.log (reg.test("ab"));//true
    console.log (reg.test("abbbbbbbbbbbbbbbb"));//true
    console.log (reg.test("abbbbbbbbcbbbbbbbbb"));//false
    console.log ("----------------")
    var reg = /^a+b+$/;
    console.log (reg.test("a"));//false
    console.log (reg.test("ab"));//true
    console.log (reg.test("abbbbbbbbbbbbbbbb"));//true
    console.log (reg.test("abbbbbbbbcbbbbbbbbb"));//false
    console.log (reg.test("aaabbbbaaabbbaaabbb"));//false
    console.log ("----------------")
    var reg = /^a{1,3}b*$/;
    console.log (reg.test("a"));//true
    console.log (reg.test("ab"));//true
    console.log (reg.test("aaaaabbbbbbbbbbbbbbbb"));//false
    console.log (reg.test("aaa"));//true
    console.log ("----------------")
    var reg = /^a{1,}b*$/;
    console.log (reg.test("a"));//true
    console.log (reg.test("ab"));//true
    console.log (reg.test("aaaaabbbbbbbbbbbbbbbb"));//true
    console.log (reg.test("aaa"));//true
    console.log ("----------------")
    //字符集
    var reg = /^[yangheli]*$/;
    console.log (reg.test("yanghelililili"));//true
    console.log (reg.test("yyyyyyyyyyyyyyyy"));//true
    console.log ("----------------")
    var reg = /^[a-f]*$/;
    console.log (reg.test("aabbbccddeeff"));//true
    console.log (reg.test(""));//true
    console.log ("----------------")
    var reg = /^[^a-f]*$/;
    console.log (reg.test("aabbbccddeeff"));//false
    console.log (reg.test(""));//true
    console.log (reg.test("wrtyAAA_ujkg"));//true
    console.log ("----------------")
    console.log ("预定义字符集");
    var reg = /^\d*$/;
    console.log (reg.test("3433253464736436"));//true
    console.log (reg.test(""));//true
    console.log (reg.test("234354r5345"));//false
    var reg = /^\s*$/;
    console.log (reg.test("    "));//true
    console.log ("特殊字符");
    var reg = /^\/*$/;
    console.log (reg.test("//"));//true
    var reg = /^.*$/;
    console.log (reg.test("fl23j4lk3nfljeworj2l你好"));
    //写一个正则,匹配一个ip地址。192.168.41.241
    var reg = /^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/;
    console.log (reg.test("192.168.41.241"));//true

    console.log (String.fromCharCode(0x4e00));//一
    console.log (String.fromCharCode(0x9fa5));//龥
    //写一个正则,来匹配2-3个子的正则。
    var reg = /^[\u4e00-\u9fa5]{2,3}$/;
    console.log (reg.test("小刚"));//true
    console.log (reg.test("a小"));//false
    console.log (reg.test("赵小刚"));//true
    console.log (reg.test("尼古拉斯赵四"));//false

    //写一个邮箱的正则表达式。
    var reg = /^[\w\.]+@\w+\.\w+$/;
    console.log (reg.test("[email protected]"));


</script>
</body>
</html>

9 split方法

支持正则作为实参的方法:split
注意:子串的匹配切割,所以不要加 ^ 和 $.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    var str = "192.168.1.1";
    //使用原有的方式切割
    console.log (str.split("."));
    //使用正则切割
    console.log (str.split(/\./));
    str = "kfjk234lwe345jrl345kjewlk54fjkl0jf";
    console.log (str.split(/\d+/));//["kfjk", "lwe", "jrl", "kjewlk", "fjkl", "jf"]
    str = "js    js             js           js";
    console.log (str.split(/\s+/));
</script>
</body>
</html>

10 replace方法

支持正则的方法:replace()
使用正则去当前字符串对象中进行子串的匹配。将匹配到的子串替换为指定的内容。
i:修饰符:代表匹配的时候忽略大小写。ignore case
g: 修饰符:全局搜索 global
修饰符是可选择的。两个修饰符可以一起使用。

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>Title</title>
</head>
<body>
<script>
   var str = "js       java         html       css";
   console.log (str.replace(/\s+/g,"-"));
</script>
</body>
</html>

11 match方法

支持正则的方法:match.
1:如果使用字符串作为实参,那么只能返回第一个匹配的子串的内容。
2:如果想找到当前字符串对象中的所有的匹配的内容,需要使用正则。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    var str = "helloworld";
    console.log (str.match("o"));
    console.log (str.match(/o/g));
    var str = "he123ll123o345657wor75ld";
    console.log (str.match(/\d+/g));
</script>
</body>
</html>

12 search方法

支持正则的方法:search
该方法类似于indexOf。返回搜索的子串的索引。不存在返回-1.
但是实参支持正则。

该方法的使用具有局限性。只能返回第一个匹配的内容的索引。
不能返回所有的。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    var str = "helloworld";
    console.log (str.search("o"));//4
    console.log (str.search(/o/g));

</script>
</body>
</html>
;