添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

在这里插入图片描述
箭头函数和普通函数使用起来没有太多的区别。

箭头函数和普通函数的区别在哪里呢?

1.箭头函数是匿名函数 箭头函数不能作为构造函数使用 不能使用new
2.箭头函数的this,始终指向父级上下文
3.箭头函数不能通过call apply bind改变this指向,但是可以通过这些方法传递参数
4.箭头函数没有原型属性
5.箭头函数没有arguments属性,可以用…展开运算符来接收所有的参数集合

如何在JavaScript函数中不传递先前参数的情况下传递第n个可选参数?

使用普通传递的方法肯定是不行的,如果你有三个形参,但是呢你只想传递1和3,但是你传递了两个参数发现1和2被赋值了,怎么样解决这个问题呢?使用对象的方式来解决

需求就是给1和三传参,但是2不需要传递参数
在这里插入图片描述

但是呢这样有点不太美观,因为还是会出现 undefined ,影响视觉体验,如何解决呢

Object.values() : 获取 object 类型的所有 value ,并且返回一个数组回来

现在的情况不管你传递多少个参数,都可以获取到你传递的参数,更加灵活多变。
在这里插入图片描述

但这也是它的缺陷。 1.实参传入被调 函数 无法交换数值。 2.当传入值大于8字节即需要进行整体拷贝,无论是开辟的空间还是数据的拷贝都相对较大(这也是设计数组退化为指针的原因),而指针 传递 只有4个字节 所以需要地址 传递 来进行 传参 。 地址 传递 地址的 传递 ,使得传入的 参数 是地址,而*解引用去操作该地址的内存,使得在被调 函数 也可以修改主调 函数 的实参值(这也是其不好的一点,看你怎么利用)。但其 传参 后还需要进 function example(a,b){ var a = arguments[0] ? arguments[0] : 1;//设置 参数 a的默认值为1 var b = arguments[1] ? arguments[1] : 2;//设置 参数 b的默认值为2 return a+b; 注意以上 函数 也可写作如下: function example(){ var a = arguments[0] ? arguments[0] : 1;//设置 第一个 参数 的默认值为1 call的实现 //context 为 可选 参数 ,如果不传的话默认上下文为 window Function.prototype.myCall = function(context) { if (typeof this !== 'function') { throw new TypeError('Er 字面量声明 书写格式: 关键字 标识符( 函数 名) 小括号 {代码块} Function f70 ( ) {代码块} 调用 函数 (执行 函数 体) 书写格式: 函数 名 小括号: function serach() { console.log(n); serach ();//n 构造 函数 声明 书写格式: 关键字 标 编程初学者在接触 JavaScript 这门 语言 时,很难搞懂里面的逻辑,这就会导致入门慢,入门难。这种难度一般主要集 函数 ,变量这块,难点以 函数 之间的 传参 ,嵌套为主。如果不调用 函数 形参 和实参都是摆设。实参可以是一个确定的数,可以是字符串,可以是对象,可以是 函数 。总而言之,实参相当于一个值, 形参 相当于一个变量,只不过这个变量没有被声明而已。 形参 和实参的关系一目了然, 形参 接受实参。 <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"... 1.今天在做项目的时候遇到一个问题,就是使用 点击事件的时候, 参数 如果为全数字就会出现点击无反应的问题。但是当 参数 为字符串或者动态内容的时候就会出现事件无法响应。比如 解决办法:是用转移字符,onclick=\"add(\\\'abc\\\')\";这样在方法 就可以使用了。 2.还有一个是在做拼接字符串的时候,如果是循环比较多的 情况 下,建议使用var ... 2019-09-19 07:48:27 """文件操作基本流程1.能调用方法的一定是对象 对象.方法2. li = [1,2,3] li . append(2) (对象) . (方法)3.文件读和写不能并存4."写"操作 会(1).清空原... 函数 默认 参数 在ES6之前,我们编写的 函数 参数 是没有默认值的,所以我们在编写 函数 时,如果有下面的需求:ES6之前需要手动编写判断,但在ES6 ,我们允许给 函数 一个默认值。 函数 剩余 参数 ES6 引用了rest parameter,可以将不定数量的 参数 放入到一个数组 : 如果最后一个 参数 是 ... 为前缀的,那么它会将剩余的 参数 放到该 参数 ,并且作为一个数组;那么剩余 参数 和arguments有什么区别呢?剩余 参数 必须放到最后一个位置,不然就会报错。...