vue入门笔记 day1

webpack属性配置

javascript(参考webpack.config.js)

const path=require(‘path’)
const htmlWebpackPlugin=require('html-webpack-plugin');
module.exports={ 
    entry:{ //main是默认入口,也可以是多入口
        main:’./src /main.js’,
    },
    output:{ //出口
        path:path.join(__dirname , ’..’ , ’dist’)’’, //最好是绝对路径
        //代表当前目录的上一级的dist
        filename:’./build.js’ //指定js文件
    },
    module:{
        //loader与rules一样的功能,rules是webpack2.x之后新加的,用一种即可
        loaders:[  
            {
                test:/\.css$/,
                loader:’style-loader!css-loader’,//顺序是反过来的2!1
            },
            {
                test:/\.(jpg|svg|png|gif)$/i,
                loader:’url-loader?limit=4096&name=[name].[ext]’,
                    // [name].[ext]内置提供的,文件名,后缀名
                options:{//参数可以拼在loader里也可以写在options里,选一种即可
                    limit:4096,
                    name:’ [name].[ext]’
                }
            }
    
        ]
    },
    plugins:[
        //插件的执行顺序是依次的,和loader是相反的
        new htmlWebpackPlugin({
            template:’./src/index.html’
            //将src下的template属性描述的文件根据当前配置的output.path,将文件移动到该目录
        })
    ]
}

webpack-ES6的处理

  • ES6的模块,vue本身默认支持es6的模块导入导出
  • babel
    • babel-loader ( 内部依赖babel-core )
      • 关键字 (presets es2015)
  • 函数 ( plugins babel-plugin-transform-runtime )

ES6中的模块

  • 默认

    • 导出export default temp;
    • 导入import defaultObj from './cal.js';
  • 声明式

    • 1导出export var obj1="我是声明式导出1"
    • 2导出export var obj2="我是声明式导出2"
    • 3单独导出var obj4="我是声明式导出4"; export {obj4};
    • 导入import {obj1,obj2,obj4} from './cal.js';
  • 全体

    • 导入import * as allObj from './cal.js'

运行结果:

Object {default: "我是默认导出的结果", obj1: "我是声明式导出1", obj2: "我是声明式导出2", obj3: "我是声明式导出3",obj4: "我是声明式导出4"…}
1.  __esModule:true
2.  default:"我是默认导出的结果"
3.  obj1:"我是声明式导出1"
4.  obj2:"我是声明式导出2"
5.  obj3:"我是声明式导出3"
6.  obj4:"我是声明式导出4"
7.  __proto__:Object
  • 默认导入和声明式导入在使用上的区别
    • 要注意:声明式导入的时候,必须名称要一致(按需导入)
    • 默认导入 可以随便使用变量名
  • import 和 export 一定要写在 顶级作用于内 ,不能写在 {}里

ES6中的代码变化

  • 对象属性的声明

var name='abc';

var person={name};  简写   - 》 var person={name:name}
  • 声明函数

var cal={
    add1:function(){
        return 1;
    },
    add2 (){
        return 2;
    }

}
  • 当属性的key与变量名相同,并且以变量值为value,就可以简写{name}->{name:name}
  • es6函数里干掉了function

vue单文件

  • 单文件就是以.vue结尾的文件。最终通过webpack也会编译成.js在浏览器运行
  • 内容:<'template'><'/template'> + <'script'><'/script'> + <'style'><'/style'>
  • 1: template中只能有一个根节点 2.x
  • 2: script中 按照 export default 来写
  • 3: style中 可以设置 scoped属性,让其只在template中生效

以单文件的方式启动

  • webpack找人来理解你的单文件代码
    • vue-loader,vue-template-compiler,代码中依赖vue
  • 启动命令
    ..\\node_modules\\.bin\\webpack-dev-server --inline --hot --open 默认8080端口
    ..\\node_modules\\.bin\\webpack-dev-server --inline --hot –open --port 8090 指定8090端口

关于启动的目录结构

my-project
    - src  存放人可以看懂的代码,具有一定的功能划分 ,mvc
    - dist 存放真实上线的代码(减少请求,混淆代码),机器能看懂
    - webpack.config.js 打包生成dist下的代码
    - package.json   包信息描述  还能做命令简化

命令行  webpack           开发   
立刻读取webpack.config.js,生成到dist目录下
webpack-dev-server     测试

运行src下的代码,虚拟出build.js 
在含有packge.json文件下
npm install       安装所有devDependencies + dependencies
npm install –production  只安装 dependencies

package.json里   npm run dev  npm run build
{
    "scripts": {   
        "dev": "..\\node_modules\\.bin\\webpack-dev-server --inline --hot --open",  开发的命令简化
        "build":"webpack"   打包代码到生产环境
    }
}

vue介绍

  • 2014年诞生,2013年react,09年angularjs
  • 作者 尤雨溪
  • 核心概念:
    组件化 双向数据流(基于ES5中的defineProperty来实现的),IE9+才支持
  • angular核心 :
    模块化 双向数据绑定(脏检测:一个数组($watch))
    • 开发一个登陆的模块,登录需要显示头部、底部、中部
    • 组件 :组合起来的一个部件 (头部、底部、中部)
    • 细分代码
      • 头部:页面、样式、动态效果
      • 代码:template style script
  • 框架对比:
    https://cn.vuejs.org/v2/guide/comparison.html

双向数据流

  • 1.js内存属性发生改变,影响页面的变化
  • 2.页面的改变影响js内存属性的改变

vue中常用的v-指令演示

  • 常用指令
  • v-text 是元素的innerText,只能在双标签中使用
  • v-html 是元素的innerHTML,不能包含
  • v-if 元素是否移除或者插入
  • v-show 元素是否显示或隐藏
  • v-model 双向数据绑定,v-bind 单向数据绑定(内存js改变影响页面)

class结合v-bind使用

  • 需要根据可变的表达式的结果来给class赋值,据需要用到v-bind:class=”xxx”
  • v-bind:属性名=”表达式”,最终表达式运算结束的结果复制给该属性名
    • 简化写法 :属性名=”表达式”
  • class:结果分类
    • 一个样式: 返回字符串(三元表达式和key和央视的清单对象)
      <div v-bind:class="isRed?'red':'green'">单个class</div> <li v-for="v in stu" :class="{'A':'red','B':'green'}[v.score]">{{v.name}}</li>
    • 多个样式: 返回对象 (样式做key,true或false做值)
      <div :class="{'red':true,'big':true}">多个class 对象方式</div>

methods 和v-on的使用

  • 绑定事件的方法
    • v-on:事件名=”表达式||函数名”
    • 简写@事件名=”表达式||函数名”
  • 函数名如果没有参数 调用时候可以不加小括号
  • 声明组件内内函数,在export default这个对象的跟属性上加上methods属性,其是一个对象
    • key 是函数名, 值是函数体
  • 在export default这个对象的跟属性上加上data属性, 其是一个对象,返回一个对象
    • 对象的属性是我们初始化的变量名称
  • 凡是在template中使用变量或者函数,不需要加this
  • 在script中使用就需要加上this

v-for的使用

  • 可以单独使用操作数组 (item,index)
  • 可以单独使用操作对象 (value,key,index)
  • key是类似track by的一个属性
  • 为的是告诉vue,js中的元素,与页面之间的关系,当视图删除元素的时候,是单个元素的删除二不是整版替换,所以需要关联其关系,设置(必须,性能) 2.xxx之后必须设置

父子组件的使用

  • 父和子 使用的是父,被用的是子
  • 父需要声明子组件,引入子组件对象,声明方式如下

javascript

import 子组件对象 from './xxxr.vue';
export default {   
    components: {
        组件名: 子组件对象
    }
}
  • 全局组件,使用更为方便,不需要申明,直接用
  • 在mian.js中引入一次,在main.js中使用Vue.component(‘组件名’,组件对象)
  • 所有的组件就可以直接通过组件名使用

父传子

  • 父组件通过子组件的属性将值进行传递
    • 方式有2
      • 常量:prop1=”常量值”
      • 变量:prop2=”变量名”
  • 子组件需要声明
    • 根属性props:[‘prop1’,’ prop2’]
    • 在页面中直接使用{{ prop1’}}
    • 在js中应该如何使用prop1? this.props1来获取

看文档的对象分类

  • 1.全局的代表Vue.的
  • 2.实例的代表this.或者new Vue().
  • 3.选项代表 new Vue()的参数 或者 export default 里边的属性

子向父组件通信(vuebus)(扩展)

  • 通过new Vue()这样的一个对象,来$on(‘事件名’,fn(prop1,prop2))
  • 另一个组件引入同样的vuebus,来$emit(‘事件名’,prop1,prop2)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,048评论 0 29
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,010评论 4 129
  • 文|[疯狂小梅子](//www.greatytc.com/users/ab6e87340565) 你或许对...
    疯狂小梅子阅读 948评论 0 11
  • 早上起床,洗漱之后,换上舒适的衣服,踩着秋日的阳光,出门吃早餐。其实最近的早餐都是自己在煮,甜甜糯糯的赤豆...
    站在树上的阳光阅读 841评论 4 1
  • 平均值mean median中位数:位于中间的,如果中间有2个,求他们平均。 众数mode:出现最多的数 极差ra...
    ATHAS阅读 697评论 0 51