博客列表 >演示条件渲染,计算属性与侦听器属性

演示条件渲染,计算属性与侦听器属性

lus菜
lus菜原创
2021年01月21日 14:38:23645浏览

条件渲染:v-if,v-show

  1. v-if: 元素是否添加到页面中
  2. v-show: 元素是否显示出来(元素已经在dom元素结构中)

样式代码:

  1. <body>
  2. <div id="app">
  3. <!-- 单分支 -->
  4. <p v-if="flag">{{msg}}</p>
  5. <button @click="flag = !flag" v-text="tips = flag ? `隐藏`: `显示`"></button>
  6. <!-- 多分支 -->
  7. <p v-if="point > 1000 && point < 2000">{{grade[0]}}</p>
  8. <p v-else-if="point >= 2001 && point < 3000">{{grade[1]}}</p>
  9. <p v-else-if="point >= 3001 && point < 4000">{{grade[2]}}</p>
  10. <p v-else-if="point >= 4000 ">{{grade[3]}}</p>
  11. <p v-else>{{grade[4]}}</p>
  12. <!-- v-show -->
  13. <p v-show="status">祝大家牛年吉祥如意</p>
  14. </div>
  15. <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  16. <script>
  17. const vm = new Vue({
  18. el: document.querySelector("#app"),
  19. data() {
  20. return {
  21. msg: "明天我请大家吃饭",
  22. flag: true,
  23. tips: "隐藏",
  24. point: 4000,
  25. grade: [
  26. "青铜会员",
  27. "白银会员",
  28. "黄金会员",
  29. "白金会员",
  30. "只对VIP开放",
  31. ],
  32. status: true,
  33. };
  34. },
  35. });
  36. </script>
  37. </body>

效果预览:

计算器属性:

  1. 计算属性,本质上就是原生的访问器属性
  2. 计算属性: 最终会和data合并,所以不要和data中已有属性重名
  3. 访问器属性有getter/setter

样式代码:

  1. <body>
  2. <div class="app">
  3. <p>数量:<input type="number" v-model="num" style="width: 3em" min="0" /></p>
  4. <p>单价: {{price}} 元</p>
  5. <p>金额: {{amount}} 元</p>
  6. </div>
  7. <script>
  8. const vm = new Vue({
  9. el: document.querySelector(".app"),
  10. data() {
  11. return {
  12. num: 1,
  13. price: 50,
  14. res: 0,
  15. };
  16. },
  17. computed: {
  18. //计算属性默认getter
  19. amount: {
  20. get() {
  21. return this.num * this.price;
  22. },
  23. set(value) {
  24. console.log(value);
  25. if (value > 1000) this.price = 80;
  26. },
  27. },
  28. },
  29. });
  30. vm.amount = 1100;
  31. </script>
  32. </body>

效果预览:

侦听器属性:

  1. 侦听器属性:监听数据对象的变化
  2. 侦听器是某一个属性的值的变化,它的属性名与data中要监听的属性同名

样式代码:

  1. <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  2. <body>
  3. <div class="app">
  4. <p>
  5. <input
  6. type="number"
  7. v-model="num"
  8. style="width: 3em"
  9. min="0"
  10. max="max"
  11. />
  12. </p>
  13. <p>单价:{{price}} 元</p>
  14. <p>金额: {{res}} 元</p>
  15. </div>
  16. <script>
  17. const vm = new Vue({
  18. el: document.querySelector(".app"),
  19. data() {
  20. return {
  21. num: 0,
  22. price: 50,
  23. res: 0,
  24. max: 100,
  25. };
  26. },
  27. // 侦听器属性
  28. watch: {
  29. num(newValut, oldValue) {
  30. console.log(newValut, oldValue);
  31. // this.res = this.num * this.price;
  32. this.res = newValut * this.price;
  33. // 监听库存
  34. if (newValut >= 20) {
  35. this.max = newValut;
  36. alert("库存不足,请联系管理");
  37. }
  38. },
  39. },
  40. });
  41. </script>
  42. </body>

效果预览:

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议