• [Falcor] Indroduce to Model


    How to work with JSON data indirectly through a Falcor Model. The Falcor Model allows you to work with data using the same familiar JavaScript path syntax. However the Model uses a push API, sending the data to a callback rather than returning it immediately. Using a push API means that you can move your data anywhere in the network later on, without changing the data retrieval code in your client.

    Below the code, show the data stay in memory, and we get the data by javascript path:

    <!-- index.html -->
    <html>
    <head>
        <!-- Do _not_  rely on this URL in production. Use only during development.  -->
        <script src="//netflix.github.io/falcor/build/falcor.browser.js"></script>
        <script>
            var model = {
              people: [
                  {
                      name: "Zhentian",
                      titles: [
                          {
                              id: 123,
                              name: "developer",
                              rating: 10
                          }
                      ]
                  },
                  {
                      name: "Otto",
                      titles: [
                          {
                              id: 321,
                              name: "developer",
                              rating: 10
                          }
                      ]
                  }
              ]  
            };
            
            console.log(model.people[0].titles[0].name);
        </script>
    </head>
    <body>
    </body>
    </html>

    You will see the "developer" in the console.

    Using farcol.Model to the data async, the data will be pushed into the console:

    <!-- index.html -->
    <html>
    <head>
        <!-- Do _not_  rely on this URL in production. Use only during development.  -->
        <script src="//netflix.github.io/falcor/build/falcor.browser.js"></script>
        <script>
            var model = new falcor.Model({
                cache: {
                    people: [
                        {
                            name: "Zhentian",
                            titles: [
                                {
                                    id: 123,
                                    name: "developer",
                                    rating: 10
                                }
                            ]
                        },
                        {
                            name: "Otto",
                            titles: [
                                {
                                    id: 321,
                                    name: "developer",
                                    rating: 10
                                }
                            ]
                        }
                    ]
                }
            });
            
            model.getValue('people[0].titles[0].name')
                    .then(function (value){
                        console.log("Falcor: ", value);
                    });
        </script>
    </head>
    <body>
    </body>
    </html>

    We still use the javascript path the repersent the data:

    'people[0].titles[0].name'

    getValue return a promise, so we use .then to get the value:

            model.getValue('people[0].titles[0].name')
                    .then(function (value){
                        console.log("Falcor: ", value);
                    });
  • 相关阅读:
    总结
    PHP的重载-使用魔术方法实现
    用PHP实现一些常见的排序算法
    MySQL分组聚合group_concat + substr_index
    各种链接地址
    在Linux服务器上使用rz命令上传文件时时老报:Segmentation Fault,上传失败
    新安装的windows 10无法更新报0x80240fff错误的解决方案
    通过SSH key获取GitHub上项目,导入到IDEA中
    解压.zip,.tar.gz文件到指定目录,重命名文件
    byte字节数组的压缩
  • 原文地址:https://www.cnblogs.com/Answer1215/p/4948883.html
Copyright © 2020-2023  润新知