Vue.js

暴力入门与组件开发

MVVM

感觉已经被掏空

10秒钟上手

{{前端模板}}
→双向绑定←
数据驱动$data
<!DOCTYPE html>
<html lang="en">
    <head>
      <title>Document</title>
    </head>

    <body>
      <div id="weibo" class="panel callout radius">
        <h1>{{ haha }}</h2>
      </div>
    
    <script src="../node_modules/vue/dist/vue.js"></script>
    <script>
      new Vue({
          el: "#weibo",
          data() {
            return {
              haha: 2333,
            };
          },
      })
    </script>
    </body>
</html>

主要概念

  • 构造器
  • 组件系统
  • 指令
  • 生命周期

构造器

new Vue({
    el: '<jQueryStyleSelector>',
    
    template: '<id || inline template>',
    
    data: {
        props: 'that are visible in templates',
        they: 'can be referenced from methods with this.propName'
        first_name: "John",
        last_name: "Doe"
    },

    computed: {
        full_name(){
            return this.first_name + this.last_name; //John Doe    
        }
    },  

    methods: {
        customMethodsAlso(){
            //here we have access to data, computed methods also
        }
    },
    // 生命周期钩子
    created: function(){},
    destroyed: function(){},

})

构造器常见选项

  • data
  • created
  • methods
  • computed
  • components
  • watch
  • props

组件系统

HTML
CSS
JS

<template></template>
<style></style>
<script></script>

m.weibo.cn v8
组件划分

CSS 选择器执行效率

1.id选择器(#myid)
2.类选择器(.myclassname)
3.标签选择器(div,h1,p)
4.相邻选择器(h1+p)
5.子选择器(ul < li)
6.后代选择器(li a)
7.通配符选择器(*)
8.属性选择器(a[rel="external"])
9.伪类选择器(a:hover, li:nth-child)

指令

Vue.directive('my-directive', {
  bind: function () {
    // 准备工作
    // 例如,添加事件处理器或只需要运行一次的高耗任务
  },
  update: function (newValue, oldValue) {
    // 值更新时的工作
    // 也会以初始值为参数调用一次
  },
  unbind: function () {
    // 清理工作
    // 例如,删除 bind() 添加的事件监听器
  }
})
<div v-my-directive="someValue"></div>

生命周期

v8目录结构

.
├── build/                      # webpack 配置文件
│   └── ...
├── config/                     
│   ├── index.js                # 项目配置文件
│   └── ...
├── src/
│   ├── main.js                 # 全局入口
│   ├── routers.js              # 路由配置
│   ├── views/                  # 路由入口文件
│   │   ├── Main.vue           # 首页feed
│   │   ├── Messages.vue       # “消息”
│   │   └── ...
│   ├── components/             # 组件们
│   │   └── ...
│   ├── filters/                # 全局过滤器
│   │   └── ...
│   └── assets/                 # 资源文件(会被 webpack 处理)
│       └── ...
├── static/                     # 纯静态资源 (不会被 webpack 处理,直接拷贝)
├── test/                       # 测试用例(暂无)
├── .babelrc                    # babel 配置
├── .editorconfig.js            # 编辑器风格配置
├── .eslintrc.js                # eslint 配置
├── index.html                  # 入口静态页模板
└── package.json                # npm 配置

Vue.js

By miccycn

Vue.js

  • 2,092