zoukankan      html  css  js  c++  java
  • [Immutable,js] Immutable.Record() as data models

    The Immutable.js Record() allows you to model your immutable data much like you would model data with native Javascript classes or objects. It differs from native classes because it cannot be mutated after it's creation and it always has a default value. It's an excellent construct in which to piece together your stores, be them Flux or some other storage implementation. Let's quickly create an Immutable Record().

    Create a Record class:

    let TodoRecord = Immutable.Record({
      id: (+new Date() + Math.floor(Math.random() * 999999)).toString(36),
      title: "Default Title",
      items: Immutable.List(),
      completed: false
    });

    Inside the Recode class, you can define the default value. But you cannot add any method!

    New a instance:

    // Create a new instance
    let imTodo = new TodoRecord({
      title: "New Title",
      items: Immutable.List(),
      completed: false
    });

    Update and get an value:

    // Update the title
    imTodo = imTodo.updateIn(['title'], val => "Immutable");
    console.log(imTodo.get('title'));

    Read the value:

    console.log(imTodo.title);
    
    let items = imTodo.items;
    let newItem = "New Item";
    let updatedItems = imTodo.push(newItem);
    
    let newTodo = imTodo.set("items", updatedItems );

    As you can see, the advantage by using Record instread of Map is that we can access the value directly by using:

    imTodo.title;

    instead of:

    imTodo.get("title") //Of course this also works
  • 相关阅读:
    T2487 公交司机(搜索题)(小L的一生)
    T2485 汉诺塔升级版(普及)(递归)
    T2483 电梯(模拟题)
    将图片返回到前端
    session
    TCP协议
    socket
    断点调试
    解析字符串
    Cookie
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5227614.html
Copyright © 2011-2022 走看看