ES6 - 对象扩展(增强字面量)

/**
 * 对象的扩展
 * 
 * 增强对象字面量
 * 
 * 解决问题:缩减代码
 */

{
  /**
   * 1.属性简表示法
   * 变量foo直接写在大括号里面。这时,属性名就是变量名, 属性值就是变量值
   */
  const foo = 'bar';
  const baz = { foo };
  // baz // {foo: "bar"}

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


  /**
   * 方法简写
   */
  const o1 = {
    method() {
      return "Hello!";
    }
  };

  // 等同于

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

{
  // 例子1
  let birth = '2000/01/01';

  const Person = {

    name: '张三',

    //等同于birth: birth
    birth,

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



  // 例子2
  function createBookShop(inventory) {
    return {
      inventory,    //属性简写  inventory:inventory,
      // inventoryValue: function () {
      inventoryValue() {
        return this.inventory.reduce((total, book) => total +
          book.price, 0);
      },
      //priceForTitle: function (title) {
      priceForTitle(title) {
        return this.inventory.find(book => book.title === title)
          .price;
      }
    }
  }

  const inventory = [
    { title: "Vue", price: 10 },
    { title: "Angular", price: 15 }
  ];

  const bookShop = createBookShop(inventory);
  console.log(bookShop.inventoryValue());         //25
  console.log(bookShop.priceForTitle("Angular")); //15

}


作者:【唐】三三

出处:https://www.cnblogs.com/tangge/p/12004047.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

posted @   【唐】三三  阅读(193)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2012-12-07 C#4.0图解教程 - 第7章 类和继承
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
点击右上角即可分享
微信分享提示