首页 > 其他分享 >对象的扩展

对象的扩展

时间:2024-04-08 11:45:39浏览次数:15  
标签:function bar const 对象 baz 扩展 return foo

对象的扩展

  1. 属性的简洁表示法

const foo = 'bar';
const baz = {foo};
baz // {foo: "bar"}

// 等同于
const baz = {foo: foo};


------------

function f(x, y) {
  return {x, y};
}

// 等同于

function f(x, y) {
  return {x: x, y: y};
}

f(1, 2) // Object {x: 1, y: 2}

  • 除了属性简写,方法也可以简写。
const o = {
  method() {
    return "Hello!";
  }
};

// 等同于

const o = {
  method: function() {
    return "Hello!";
  }
};
-------------------


let birth = '2000/01/01';

const Person = {

  name: '张三',

  //等同于birth: birth
  birth,

  // 等同于hello: function ()...
  hello() { console.log('我的名字是', this.name); }

};
  • 用于函数的返回值

function getPoint() {
  const x = 1;
  const y = 10;
  return {x, y};
}

getPoint()
// {x:1, y:10}

  • CommonJS 模块输出一组变量,就非常合适使用简洁写法

let ms = {};

function getItem (key) {
  return key in ms ? ms[key] : null;
}

function setItem (key, value) {
  ms[key] = value;
}

function clear () {
  ms = {};
}

module.exports = { getItem, setItem, clear };
// 等同于
module.exports = {
  getItem: getItem,
  setItem: setItem,
  clear: clear
};


  • 属性的赋值器(setter)和取值器(getter),事实上也是采用这种写法。

const cart = {
  _wheels: 4,

  get wheels () {
    return this._wheels;
  },

  set wheels (value) {
    if (value < this._wheels) {
      throw new Error('数值太小了!');
    }
    this._wheels = value;
  }
}

  • 简洁写法在打印对象时也很有用

let user = {
  name: 'test'
};

let foo = {
  bar: 'baz'
};

console.log(user, foo)
// {name: "test"} {bar: "baz"}
console.log({user, foo})
// {user: {name: "test"}, foo: {bar: "baz"}}

  • 上面代码中,console.log直接输出user和foo两个对象时,就是两组键值对,可能会混淆。把它们放在大括号里面输出,就变成了对象的简洁表示法,每组键值对前面会打印对象名,这样就比较清晰了

  • 注意,简写的对象方法不能用作构造函数,会报错


const obj = {
  f() {
    this.foo = 'bar';
  }
};

new obj.f() // 报错

  • 上面代码中,f是一个简写的对象方法,所以obj.f不能当作构造函数使用。

标签:function,bar,const,对象,baz,扩展,return,foo
From: https://www.cnblogs.com/fszj/p/18120804

相关文章

  • immer 不可变对象状态管理的工具
    immer是一个不可变对象状态管理的node包,一般主要场景应用到react等项目中,当然node项目也是可以使用的优点遵循不可变数据流强类型开箱即用的结构共享开箱即用的对象冻结jsonpatche支持gzip之后比较小内部参考处理如下图参考资料https://immerjs.github.io/imm......
  • VS+QT编程找不到新增UI文件控件对象的问题
    转载自:VS写Qt项目时,ui界面拖拽的控件代码找不到引用的解决办法_vsqt中ui下的组件没有-CSDN博客1.保存Ui文件在拖拽控件之后,Ctrl+S2.重新编译ui文件鼠标右键选择要编译的UI文件,找到编译 3.右键项目,重新扫描解决方案 ......
  • c++类与对象<三>初始化列表,静态成员,友元,匿名对象
    目录前言一:再次认识构造函数之成员初始化列表初始化成员变量1.类对象整体的定义与对象中每个成员变量的定义2.初始化列表3.explicit 关键字二:static成员 1.概念2.经典实例:实现一个类,计算程序中创建出了多少个类对象3.特点总结 三:匿名对象 1.匿名对象就像结构体......
  • Mapster (C# 对象映射器)
    参考:https://www.cnblogs.com/qiqigou/p/13696669.html官方文档:https://github.com/MapsterMapper/Mapster/wiki前言谈到对象映射器,AutoMapper知名度是非常的高,但很少有人知道Mapster。性能优于AutoMapper安装MapsterInstall-PackageMapster 或者 dotnetaddpackageM......
  • 最小生成树及扩展应用
    文章目录一、最小生成树1.1概念1.2定理一1.2.1内容1.2.2证明1.2.3推论1.3基于定理一推论的MST算法1.3.1Kruscal算法1.3.1.1算法原理1.3.1.2算法流程1.3.1.3代码实现1.3.2Prim算法1.3.2.1算法原理1.3.2.2算法流程1.3.2.3代码实现二、OJ练习2.1POJ125......
  • 哪些代码设计看似是面向对象,实际是面向过程的?
    1.滥用getter、setter方法在设计实现类的时候,除非真的需要,否则尽量不要给属性定义setter方法。除此之外,尽管getter方法相对setter方法要安全些,但是如果返回的是集合容器,那也要防范集合内部数据被修改的风险。2.Constants类、Utils类的设计问题对于这两种类的设计,我......
  • day21java学习打卡:匿名对象的使用
    /* *一.理解“万事万物皆对象” *1.在java语言范畴中,我们的都将功能,结构封装到类中,通过类的实例化, *来调节具体的功能结构 *  >Scanner,String *  >文件:File *  >网络资源:URL *2.涉及到Java语言与前端HTML,后端的数据库交互时,前后端的结构在ja......
  • python学习--基础知识(字符串扩展)
    八、字符串扩展1、字符串的三种定义方式2、字符串的拼接3、字符串的格式化4、字符串格式化的精确度控制5、字符串格式化的快速方法6、字符串格式化--对表达式进行格式化......
  • 【Kotlin】类和对象
    1前言​Kotlin是面向对象编程语言,与Java语言类似,都有类、对象、属性、构造函数、成员函数,都有封装、继承、多态三大特性,不同点如下。Java有静态(static)代码块,Kotlin没有;Java有静态(static)函数,Kotlin没有;Java构造函数名与类名相同,Kotlin构造函数名为constructor;......
  • 【SQL】数据定义语言(DDL):包括创建、修改和删除数据库对象
    数据定义语言(DDL)是用于定义和管理数据库中的数据结构和对象的SQL语言子集。它允许用户创建、修改和删除数据库中的表、索引、触发器、序列、存储过程等对象。DDL语句在数据库系统中执行时,通常会影响整个数据库的结构,而不是单个的数据记录。以下是DDL中一些常用语句的详细介绍......