Vue.js 数组复制的问题

2017-04-09 19:40:37 +08:00
 qfdk

vue.js 直接上代码 打算做一个利用 algolia 搜索的工具,引用了官方 api 可以查询,想把结果放在数组里面,然后显示出来. 然而 用了 index.search 的方法可以得到数据,但是循环结束之后数据就没有了. 也就是 1 有回显 2 无回显 this.searchResult 应该算是全局变量吧,为什么会丢失数据呢?难道需要进行数组的复制? 求解 先谢过.

  data() {
    return{
      query:'',
      searchResult:[],
    }
  },
  methods:{
    search:function()
    {
      var client = algoliasearch('xxx', 'xxx')
      var index = client.initIndex('getstarted_actors')
      index.search(this.query,function(err, content) {
        content.hits.forEach(function(e,index){
          this.searchResult.push(e)
        },this)
        console.log('1'+this.serarchResult) // 有回显
      });
       console.log('2'+this.serarchResult) // 无显示数据
    }
  }

先谢过大家

5418 次点击
所在节点    程序员
14 条回复
ck65
2017-04-09 19:46:13 +08:00
index.search() 是个异步方法吧,所以 2 执行的时候 this.$data.searchResult 仍然是空数组,然后等回调执行完毕后 this.$data.searchResult 才有值,所以 1 就能打印了。
qfdk
2017-04-09 19:50:37 +08:00
@ck65 那应该如何解? 用 sleep? 总感觉不科学
qfdk
2017-04-09 19:56:42 +08:00
@ck65 似乎不是这样的,用了 setinterval 打印出来是 undefined

```
index.search(this.query,function(err, content) {
var tmp=[]
content.hits.forEach(function(e,index){
tmp.push(e)
},this)
this.searchResult=JSON.parse(JSON.stringify(tmp))
console.log(this.searchResult);
});
```
这样会打印出来 object 但是 webui 并没有显示出来也就是 this.searchResult 最后还是空
ljcarsenal
2017-04-09 20:09:18 +08:00
Vue.netxtTick
qfdk
2017-04-09 20:10:15 +08:00
@ljcarsenal 好 我去看一下
lijsh
2017-04-09 20:15:52 +08:00
我觉得一楼是对的,至于没显示出来,可能是 this 丢失了。
ipwx
2017-04-09 20:18:54 +08:00
在回调外面 var self = this; 然后回调里面用 self.
qfdk
2017-04-09 20:20:19 +08:00
@ljcarsenal 似乎不可以
qfdk
2017-04-09 20:21:03 +08:00
@lijsh
@ipwx
我去试一下,似乎还是没明白 我试一下
smallpath
2017-04-09 20:22:27 +08:00
用箭头函数拜托,第一层 search 的回调用 function 就已经把 this 给丢了, forEach 第二个参数上下文这个时候 this 已经是 undefined 了。
qfdk
2017-04-09 20:22:43 +08:00
@ck65
@lijsh
@ipwx
感谢你们确实是这样 this 丢失了!
qfdk
2017-04-09 22:37:33 +08:00
@smallpath 刚才又看了下尖头函数 原来这样不会产生新的上下文 谢谢你的分析 又学东西了
jimliang
2017-04-10 10:20:07 +08:00
javascript 两大基础: 异步和 this 作用域
qfdk
2017-04-10 13:51:29 +08:00
@jimliang 🙏 说的极是 感觉还有好多要学习

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/353627

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX