2

我正在使用“if”和“else-if”,但给了我编译错误。

[Vue 警告]:无法解析指令:else-if

这是我的代码

var app = new Vue({
  el:"#app",
  data:{
      lab_status : 2
  }
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/1.0.28/vue.js"></script>
<div id="app">
  <span v-if="lab_status==0">Inactive</span>
  <span v-else-if="lab_status==1">Active</span>
  <span v-else>Expired</span>
</div>

请帮我解决这个问题。

4

3 回答 3

3

v-else-if在 vue 2.1.0 中添加但您使用的是 version 1.0.28,这就是错误的原因,更新 vue 版本或v-if仅使用

<span v-if="lab_status==0">Inactive</span> 
<span v-if="lab_status==1">Active</span> 
<span v-if="lab_status!=1 && lab_status!=0">Expired</span>

v-else-if

于 2017-07-17T12:00:43.383 回答
3

我认为您对 v-if 和 v-else 的使用有些错误。

请检查您是否同时有带有 v-if 和 v-else 的标签。

<span v-else v-if="lab_status==1">Inactive</span>

您可以改用 v-else-if。

于 2020-11-10T05:53:54.110 回答
1

这个文件 v-else-if指令

2.1.0 中的新功能

所以更新你的 vuejs 版本

现在你只能使用v-ifv-else

<span v-if="lab_status==0">Inactive</span>
<span v-if="lab_status==1">Active</span>
<span v-if="lab_status!=0&&lab_status!=1">Expired</span>

注意:在您的情况下,您只能使用v-if。如果您使用v-else, 则lab_status=0两者都InactiveExpired显示。

于 2017-07-17T12:01:53.243 回答