vue_day02

1.绑定事件指令 v-on

 <body>
<div id="app">
<button v-on:click="num++">按钮1</button>
<button @click="num++">按钮2</button>
<button @click="countSum()">按钮3</button>
<button @click="countSum">按钮4</button> <button @click="say('师姐')">按钮5</button><br/>
{{num}}
</div>
</body>
<script type="text/javascript">
new Vue({
el: "#app",
data: {
num: 0
},
methods: {
countSum(){
this.num++;
},
say(msg) {
alert("你好!" + msg);
}
}
})
</script>

2.计算属性 computed

 <body>
<div id="app">
前台页面拼接:{{new Date(birthday).getFullYear() + "年" + new Date(birthday).getMonth() + "月" + new Date(birthday).getDay() + "日"}}<br/>
使用计算属性:{{formatterDate}}<br/>
</div>
</body>
<script type="text/javascript">
new Vue({
el: "#app",
data: {
birthday:1529032123201
},
computed:{
formatterDate(){
return new Date(this.birthday).getFullYear() + "年" + new Date(this.birthday).getMonth() + "月" + new Date(this.birthday).getDay() + "日";
}
}
})
</script>

3.监控值得变化 watch

watch 可以让我们监控一个值的变化。从而做出相应的反应。

 <body>
<div id="app">
<input type="text" v-model="newMsg"/><br/>
{{"newMsg:" + newMsg}}<br/>
{{"oldMsg:" + oldMsg}}<br/>
</div>
</body>
<script type="text/javascript">
new Vue({
el: "#app",
data:{
newMsg:"newMsg",
oldMsg:"oldMsg"
},
watch:{
newMsg(newValue, oldValue) {
this.newMsg = newValue;
this.oldMsg = oldValue;
}
}
})
</script>

4.vue组件

(1)以前组件: Component  --easyui 组件 datagrid tabs menu...panel,dialog

Vue组件: 自定义的代码块或者自定义标签 <atag></atag>

(2)组件有什么用:

(1)可以反复使用

(2)完成一些功能

(3)vue里面组件分类

全局组件:任意地方都可以使用,任意挂载的标签都使用

局部组件:只能在当前的挂载的标签里面的使用

vue组件是vue里面比较重要知识点

4.1 全局组件

 <body>
<div id="app">
<dyier></dyier>
<mydyier></mydyier>
</div>
<div id="app1">
<dyier></dyier>
<mydyier></mydyier>
</div>
</body>
<script type="text/javascript">
//全局组件
Vue.component("dyier",{
template:"<h3>h3标题的dyier</h3>"
}); var mydyier = {
template: "<h2>h2标题的dyier</h2>"
};
Vue.component("mydyier", mydyier); new Vue({
el: "#app",
});
new Vue({
el: "#app1",
});
</script>

4.2 局部组件

 <body>
<div id="app">
<dyier></dyier>
<mydyier></mydyier>
</div>
<div id="app1">
<dyier></dyier>
</div>
</body>
<script type="text/javascript">
new Vue({
el: "#app",
components:{
"dyier":{
template:"<h1>h1标题的dyier</h1>"
},
"mydyier":{
template: "<h2>h2标题的mydyier</h2>"
}
}
}); new Vue({
el: "#app1"
});
</script>

4.3 组件template里面模板的写法

 <body>
<div id="app">
<dyier></dyier>
<mydyier></mydyier>
</div>
<!-- 方式一 template标签的方式 -->
<template id="dyier">
<h1>template标签引用的方式</h1>
</template> <!--方式二 用script的方式-->
<script type="text/template" id="myDyier">
<h2>script template标签的方式</h2>
</script>
</body>
<script type="text/javascript">
//方式一:直接以字符串的方式写出来
/*new Vue({
el: "#app",
components:{
"dyier":{
template:"<h1>h1标题的dyier</h1>"
},
"mydyier":{
template: "<h2>h2标题的mydyier</h2>"
}
}
});*/ //方式二,引用
new Vue({
el: "#app",
components:{
"dyier":{
template: "#dyier"
},
"mydyier":{
template: "#myDyier"
}
}
})
</script>

4.4 模板里面的data数据必须是函数

 <body>
<div id="app">
<dyier></dyier>
<hr/>
<!-- 取到的值是data里面的name("德莱厄斯")-->
{{name}}
</div>
<!-- 方式一 template标签的方式 -->
<template id="dyier">
<form>
<!-- 会找template组件里面的name("dyier"),不会找data里的name("德莱厄斯")-->
{{name}}:<input type="text"/>
</form>
</template>
</body>
<script type="text/javascript">
new Vue({
el: "#app",
data: {
name: "德莱厄斯"
},
components: {
"dyier": {
template: "#dyier",
data: function () {
return {
"name": "dyier"
}
}
}
}
})
</script>

5. 路由

找路

vue路由: 定位到一个组件 类似于<a href="">

5.1 路由的使用

(1)安装 路由

npm install vue-router

npm uninstall vue-router

(2)在页面引用vue-router.js文件

<script type="text/javascript" src="node_modules/vue-router/dist/vue-router.js"></script>

(3)使用

 1 <body>
2 <div id="app">
3 <!-- router-link相当于a标签-->
4 <router-link to="/">首页</router-link>
5 <router-link to="/employee">员工列表</router-link>
6 <router-link to="/product">产品列表</router-link>
7 <!-- 路由出口-->
8 <router-view></router-view>
9 </div>
10 </body>
11 <script type="text/javascript">
12 //定义组件
13 var index = Vue.component("index", {
14 template: "<h1>欢迎来到首页</h1>"
15 });
16 var employee = Vue.component("employee", {
17 template: "<h2>查看员工列表</h2>"
18 });
19 var product = Vue.component("product", {
20 template: "<h2>查看产品列表</h2>"
21 });
22 //创建一个路由
23 var routes = new VueRouter({
24 routes: [{
25 path: "/",
26 component: index
27 }, {
28 path: "/employee",
29 component: employee
30 }, {
31 path: "/product",
32 component: product
33 }]
34 });
35
36 new Vue({
37 el: "#app",
38 //把路由挂在到vue上
39 router:routes
40 })
41 </script>

6. webpack打包

把项目里面内容(js,css,img等)这些资料进行打包

6.1 为什么需要打包 -->项目开发完之后

(1)减少单页面内的衍生请求次数,提高网站效率

(2) 将ES6的高级语法进行转换编译,以兼容老版本的浏览器。

导入 导出

(3)可以进行代码混淆  提高安全性

6.2 webpack

Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分

析,然后将这些模块按照指定的规则生成对应的静态资源。

6.3 使用webpack --打包js文件

(1)下载安装

npm install -g webpack

npm install -g webpack-cli

(2)创建两个js文件

a.js

 var a ="测试a";
var b = require("./b.js"); console.log(a);
console.log(b)

b.js

 define(function(){
var b = "测试b";
return b;
});

执行命令:

webpack src/a.js -o dist/bundle.js

6.4 css打包

步骤一:

npm install style-loader --save-dev

npm install css-loader --save-dev

步骤二:

a.js引用

 var a ="测试a";
var b = require("./b.js"); console.log(a);
console.log(b);
require("../css/index.css");

步骤三:在webpack.config.js文件引入下面代码

 var path = require("path");
module.exports = {
entry: './js/a.js',
output: {
path: path.resolve(__dirname, './dist'),
filename: 'bundle.js'
},
module: {
rules: [
{
test: /\.css$/, //匹配文件规则
use: ['style-loader', 'css-loader'] //匹配后使用什么加载器进行模块加载
// webpack use的配置,是从右到左进行加载的
},
]
}
};

步骤四:打包:webpack

6.5 部署项目

把前端内容放入服务里面运行

(1)安装

npm install webpack-dev-server --save-dev

(2)package.json配置

 "scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"dev": "webpack-dev-server --inline --progress --config ./webpack.config.js"
}
版本兼容性:
"webpack": "^3.10.0",
"webpack-dev-server": "^2.9.7"

(3)运行 npm run dev命令 启动服务

ctrl+c --->y 停止服务

7. Vue的脚手架

Vue脚手架 --就是前端项目的模板(已经就有一些内容)

7.1 使用脚手架

(1) 安装脚手架

npm install -g vue-cli

(2)创建一个项目

(3)执行 vue init webpack

询问创建项目 yes

询问vue-router yes

... no

(4)运行命令

npm run dev

vue_day02的更多相关文章

随机推荐

  1. 大数据面试题(一)----HADOOP 面试题

    1. 下列哪项通常是集群的最主要瓶颈(C) A. CPU B. 网络 C. 磁盘IO D. 内存 2. 下列哪项可以作为集群的管理工具?(C) A.Puppet B.Pdsh C.ClouderaMa ...

  2. Oracle监听器

    Oracle 监听器 Listener 是一个重要的数据库服务器组件,在整个 Oracle 体系结构中,扮演着重要的作用.它负责管理 Oracle 数据库和客户端之间的通讯,它在一个特定的网卡端口(默 ...

  3. 1、通过CP数据文件的方式恢复MySQL 从库 启动后报错:Last_IO_Errno: 1236:A slave with the same server_uuid/server_id as this slave has connected to the master;

    1.问题: MySQL从库中查看主从状态: show slave status\G,发现出现IO的报错: Last_IO_Errno: Last_IO_Error: Got fatal error f ...

  4. Windows玩转Kubernetes系列3-Centos安装K8S

    以往文章参考: Windows玩转Kubernetes系列1-VirtualBox安装Centos Windows玩转Kubernetes系列2-Centos安装Docker 安装K8S yum in ...

  5. SpringMVC 参数映射与文件上传

    handler参数映射: 接下来就是Spring的各个处理细节了,无论框架如何疯转其实我们处理请求的流程是不变的,设计到的操作也是固定的,举个例子,当我们要实现一个登陆功能时: 创建一个用于处理登录请 ...

  6. How to setup backup by using EMC NW + EMC NMM for sqlserver failover cluster (not always on)

    As we said, sqlsever fail over cluster is perviously version of always on. The HA was guarenteed by ...

  7. c++ 中变量成员的初始化时机

    代码如下: 注意一下我打断点的位置. 最后的结果: 在程序进入MyTest()的函数体之前,控制台就打印出来了I have been constructed. 即:在进入构造函数的函数体之前,类中的成 ...

  8. hbase架构和读写过程

    转载自:https://www.cnblogs.com/itboys/p/7603634.html 在HBase读写时,相同Cell(RowKey/ColumnFamily/Column相同)并不保证 ...

  9. linux硬盘分区、格式化、挂载超详细步骤(fdisk/parted))

  10. 高并发之——不得不说的线程池与ThreadPoolExecutor类浅析

    一.抛砖引玉 既然Java中支持以多线程的方式来执行相应的任务,但为什么在JDK1.5中又提供了线程池技术呢?这个问题大家自行脑补,多动脑,肯定没坏处,哈哈哈... 说起Java中的线程池技术,在很多 ...