添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《 阿里云开发者社区用户服务协议 》和 《 阿里云开发者社区知识产权保护指引 》。如果您发现本社区中有涉嫌抄袭的内容,填写 侵权投诉表单 进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

1. 前言


1.学徒一茬一茬的,但是问题都差不多,是时候总结下了

2.主要是vue2

3.大部分问题官网都有答案,所以还是建议先熟悉下 vue响应式原理

4.只精简出简要能体现错误原因的代码


2. 注意事项


1.官网的这句话非常重要

2.由于 JavaScript 的限制,Vue 不能检测数组和对象的变化 。尽管如此我们还是有一些办法来回避这些限制并保证它们的响应性


3. 修改数组界面不更新


典型的场景
  1. 通过索引直接赋值 ,进行数组的修改
  2. 通过长度来删除或者清空数组

3.1 修改 数组元素和长度


var vm = new Vue({
  data: {
    nums: [1,2,3,4,5,6]
methods:{
  change(){
      this.nums[2]="yzs"  // 不是响应性的
     this.nums.length=0
vm.nums[1] = 'x' // 不是响应性的
vm.nums.length= 0 // 不是响应性的


3.2 解决方案 修改数组元素

1.第一种就是通过 vue 的 set 方法来修改

2.第二种就是通过可以修改原数组的 方法进行修改


Vue.set(vm.nums, indexOfItem, newValue)
vm.$set(vm.nums, indexOfItem, newValue)
vm.nums.splice(indexOfItem, 1, newValue)


3.3 解决方案 修改数组长度


vm.nums.splice(newLength)



4.数组总结


官网

)BCYP45$J}KK])[57X%WMY6.png



5. 对象


9_23F0QG}@$KFZEXZO2T3$I.png


5.1 代码


var vm = new Vue({





    
  data:{
   user:{name:"yzs"}
methods:{
  change(){
      this.user.name="可以"  
     this.user.age=30 // 不是响应性的
// `vm.a` 是响应式的
vm.b = 2
// `vm.b` 是非响应式的


5.2 解决方案

1.对于已经创建的实例,Vue 不允许动态添加根级别的响应式 property

2. Vue.set(vm.someObject, 'b', 2)

3. this.$set(this.someObject,'b',2)


5.3 错误代码

尤其在表单操作常见


`Object.assign(this.someObject, { a: 1, b: 2 })`


5.4解决


this.someObject = Object.assign({}, this.someObject, { a: 1, b: 2 })



6. 动态路由


6.1 场景

配置动态路由 比如"/home/:id"


6.2 解决

1.监听/watch $route的变化


watch: {
   '$route': function() {
      this.newsId= this.$route.params.id
 }


  1. router-view 绑定 key
    key 用于diff算法 ,所以不同的key 切换会触发更新


<router-view :key="key"></router-view>



后记


其实这都是从官网复制的,只是很多人习惯直接百度, google,而不是看官网,所以我就搬运下,希望大家平常还是多看看官网




SpringBoot中的异常处理与参数校验_2
兄弟们好,这次来跟老铁交流两个问题,异常和参数校验,在说参数校验之前我们先来说异常处理吧,因为后面参数的校验会牵扯到异常处理这块的内容。   说到异常处理,我不知道大家有没有写过或者遇到过如下的写法。
dasein58