0

我正在使用 vue.js 和 vue-qrcode 我将一些用户数据存储在 localStorage 中并正确获取。

<template>
    <div class="row" style="100%;">
        <div class="center-block" style="width:200px">
            <qrcode :size="size" :val="val"></qrcode>
        </div>
    </div>
    {{content.last}}
</template>
<script>
    import store from '../store'
    var content = [];
    export default {
        data() {
                return {
                    content: store.todoStorage.fetch(),
                    size: 250,
                    fgColor: '#007a33',
                    bgColor: '#ffc72c',
                    val: "BEGIN:VCARD\r\nVERSION:2.1\r\nN:john;doe\r\nFN:asd " + content.last + "\r\nTEL;TYPE=cell:234\r\nEMAIL;PREF;INTERNET:234234\r\nEND:VCARD"
                }
            },
            components: {
                qrcode: VueQr
            },

    }

</script>

我尝试将字符串放入模板中,它可以工作,但是 QR 格式不正确。如果我删除变量并仅在 data() val 模型中使用文本,则 QR 是完美的并且可以正常工作。但是,我需要从上面的内容模型中获取 4 个值。

4

1 回答 1

1

如果没有看到你的整个 Vue 应用程序,很难说清楚。这是肯定的,你不能content.last在你的val对象中使用它,因为它是未定义的。基本上你是在它存在之前分配它。计算对象应该对此有所帮助。

就像是:

computed: {
  val() {
    var content = store.todoStorage.fetch();
    return "BEGIN:VCARD\r\nVERSION:2.1\r\nN:john;doe\r\nFN:asd " + content.last + "\r\nTEL;TYPE=cell:234\r\nEMAIL;PREF;INTERNET:234234\r\nEND:VCARD"
  }
}

同样,不确定这是否会在没有看到您的代码的情况下解决,但它可能会让您走上正确的道路。

于 2016-07-07T13:33:07.563 回答