如何从vue.js上的数据调用方法?

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方法将每个转换为小写并将空格转换为 -

似乎它不能从数据中调用方法

我该如何解决错误?

gvl*_*sov 9

如果您有一个函数data将在另一个对象的上下文中使用(例如事件处理程序),则this不会指向 Vue 实例。您必须在以下范围内的另一个变量中保留引用data()

methods: {
    shuffle() {}
},
data() {
    var self = this;
    return {
        onClick: function() {
            self.shuffle()
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 我一直在寻找这个来在 vuetify 验证中实现 i18n (翻译)。它就像一个魅力。我快把我逼疯了。谢谢你!....根据你的例子,我做了 self.$t('message') 并且它有效。 (3认同)

The*_*Hat 8

从vue对象中访问数据或方法时,请使用this.thing.在你的情况下,那将是this.strSlug(this.shop.name).


Bro*_*iat 7

即使使用“this”也不起作用。因为在初始化数据时该函数尚未定义。我认为你必须在created()生命周期钩子中完成它。