sam*_*toh 8 javascript vue.js vue-component vuex vuejs2
我的vue组件是这样的:
<template>
...
<ul class="nav nav-tabs nav-tabs-bg">
<li v-for="tab in tabs" role="presentation" :class="setActive(tab.url)">
<a :href="baseUrl + tab.url">{{tab.title}}</a>
</li>
</ul>
...
</template>
<script>
export default {
props: ['shop'],
data() {
return{
tabs: [
{
title: 'product',
url: '/store/' + this.shop.id + '/' + strSlug(this.shop.name)
},
{
title: 'info',
url: '/store/' + this.shop.id + '/' + strSlug(this.shop.name) + '/info'
}
]
}
},
methods: {
setActive(pathname){
return {active: window.location.pathname == pathname}
},
strSlug: function(val) {
return _.kebabCase(val)
}
}
}
</script>
Run Code Online (Sandbox Code Playgroud)
如果代码运行,则存在如下错误:
[Vue警告]:data()中出错:"ReferenceError:未定义strSlug"
如果我是console.log(window.location.pathname),结果如下:
/存储/ 21 /切尔西灾害店内
因此,如果它与包含标签中的数据的url相同,那么它将处于活动状态
我调用strSlug方法将每个转换为小写并将空格转换为 -
似乎它不能从数据中调用方法
我该如何解决错误?
如果您有一个函数data将在另一个对象的上下文中使用(例如事件处理程序),则this不会指向 Vue 实例。您必须在以下范围内的另一个变量中保留引用data():
methods: {
shuffle() {}
},
data() {
var self = this;
return {
onClick: function() {
self.shuffle()
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9582 次 |
| 最近记录: |