我已将vue 1.0.18 min.js包含在html页面的脚本标记中。Vue js应用程序未在应用程序内定义
specialText行不起作用。
var tagApp;
window.onload = function() {
/* Vue Js App here */
tagApp = new Vue({
el: '#app',
data: {
title: 'Title',
chars: [{
name: "Jarred",
attack: 15,
health: 70,
special: "Block",
blockVal: 5,
specialText: "Passive: Blocks "+ tagApp.chars[0].blockVal +" Damage."
// line above: here it doesn't work
// gives: "can't get chars of undefined"
}, {
name: "John"
}]
}
}); // close app
alert(tagApp.chars[0].blockVal); // here it works
getBlockVal(); // here it also works
} // close window.onload
function getBlockVal() {
var arr = [{
name: "henry",
description: "blocks " + tagApp.chars[0].blockVal + " dmg."
}];
alert(arr[0].description);
}
我也试着SPECIALTEXT以下内:
this.blockVal
给出定义。
this.parent.blockVal
给出未定义。
this.chars[0].blockVal
说明字符是未定义的。
tagApp.chars[0].blockVal
说tagApp是未定义的。
请帮忙。
这工作。谢谢!但是,当我改变blockVal,specialText仍然使用旧的blockVal值,因为创建只调用一次。所以我添加了一个方法来更新specialText,它的工作原理。 – MathewT
太棒了!不知道为什么人们低估了我的答案。 –