zoukankan      html  css  js  c++  java
  • 《vue.js2.0从入门到放弃》学习之路

    原文地址:

    Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374

    Vue.js2.0从入门到放弃---入门实例(二):http://blog.csdn.net/u013182762/article/details/53027883

    Vue.js2.0从入门到放弃---入门实例(三):http://blog.csdn.net/u013182762/article/details/53488870

    有幸看到作者的这3篇从入门到放弃,带我真正开始了vue.js的旅程,看完了这3篇文章,坑也踩了不少,不过还好,最后还是完美落幕,把详情页也补充进来了。

    因为我是有安装eslint的,所以对代码的格式要求很高,哪怕一个空格都不会放过,作者在入门实例(三)里面有提到,按照他的代码是会报很多错误的,不过我已经把错误都解决的了,简单罗列几个,如果还有别的error可以一起解决~

    在main.js文件里面,new实例前面要加上这2句注释。

    /* eslint-disable no-new */
    /* eslint-disable no-unused-vars */
    new Vue({
      el: '#app',
      data () {
        return {
          transitionName: 'slide'
        }
      },
      router,
      watch: {
        '$route' (to, from) {
          const toDepth = to.path.substring(0, to.path.length - 2).split('/').length
          const fromDepth = from.path.substring(0, from.path.length - 2).split('/').length
          this.transitionName = toDepth < fromDepth ? 'slide_back' : 'slide'
        }
      }
    })

    home.vue文件里面的list标签,有for循环,所以要加上key值

    <div class="content">
       <ul class="cont_ul">
          <list v-for="(item, index) in items" :price="item.price" :title="item.title" :img="item.img" :key="item.id" :index="index"></list>
       </ul> 
    </div>

    详情页主要是要拿到li里面的内容,那就必须拿到li的index,所以在home.vue里面循环的时候要把index定义出来,上面代码已经有了。我的处理方法是把跳转的地址加上index作为参数,再通过拿到这个参数,来决定详情页显示什么。一开始我以为用

    this.$route.query拿到是就是个数值,没想到这样拿到的居然是个对象,就只能再处理一遍了。details是我自己在json文件里面加的值,用于显示详情的,可以自由更改。以下是Detail.vue里面的代码,css没变,我就不再重复:
    <template>
        <div class="detail">
        
            <detail-header></detail-header>
        
            <img :src=imgSrc alt="">
        
            <p>{{details}}</p>
        
        </div>
    </template>
    <script>
    import DetailHeader from '../components/DetailHeader'
    
    export default {
      data () {
        return {
          imgSrc: '',
          details: ''
        }
      },
      components: {
        DetailHeader
      },
      created () {
        this.fetchData()
      },
      methods: {
        fetchData () {
          this.$http.get('/api/books')
            .then(res => {
              var i = this.$route.query
              var result = res.data
              for (var key in i) {
                this.imgSrc = result.data[key].img
                this.details = result.data[key].details
              }
            }, error => {
              console.log(error)
            })
        }
      }
    }
    </script>

    DetailHeader.vue的代码:

    <template>
        <header class="header">
        
            <div class="header_inner flexWrap">
        
                <div id="header_btn_nav" class="header_btn header_btn_back" v-on:click="goBack">返回</div>
        
                <div class="header_cont flex">{{title}}</div>
        
                <div class="header_btn header_btn_cart"></div>
        
            </div>
        
        </header>
    </template>
      
    <script>
    import List from '../components/List'
    export default {
      data () {
        return {
          title: ''
        }
      },
      methods: {
        goBack () {
          window.history.back()
        },
        fetchData () {
          this.$http.get('/api/books')
            .then(res => {
              var i = this.$route.query
              var result = res.data
              for (var key in i) {
                this.title = result.data[key].title
              }
            }, error => {
              console.log(error)
            })
        }
      },
      components: {
        List
      },
      created () {
        this.fetchData()
      }
    }
    </script>

    这detail的文件里面有重复的脚本,我想应该还是可以再优化的,目前水平还不够,只是能实现功能,要是有大神指导请多多赐教。

     自身不足:

    组件之间的通信

    函数与html之间的联系

    数据的请求

  • 相关阅读:
    我是如何基于angular+requirejs+node做SPA项目架构的
    阿里云无线&前端团队是如何基于webpack实现前端工程化的
    angularjs源码分析之:angularjs执行流程
    你所必须掌握的三种异步编程方法callbacks,listeners,promise
    自从用了Less 编写css,你比以前更快了~
    对象的深浅拷贝
    throttle/debounce: 为你的cpu减减压(前端性能优化)
    jekyll : 使用github托管你的博客
    html5 drag api详解
    用setTimeout 代替 setInterval实时拉取数据
  • 原文地址:https://www.cnblogs.com/hongyafang/p/7991967.html
Copyright © 2011-2022 走看看