码迷,mamicode.com
首页 > Web开发 > 详细

VueJs学习笔记

时间:2018-04-29 17:41:47      阅读:1370      评论:0      收藏:0      [点我收藏+]

标签:http请求   document   马来西亚   tail   static   数据绑定   serve   under   实例   

技术分享图片 
技术分享图片
在cmd下,进入目录之后
cd 到项目目录下
1 安装node
cnpm install
 
2 启动或者调试
cnpm start (或是npm run dev)
3
上线:
npm run build
--------------------------------------------------------------------
# install dependencies npm install # serve with hot reload at localhost:8080 npm run dev # build for production with minification npm run build
------------------------------------------------------
# install dependencies npm install # run server npm start
-----------------------------------------
 
vue全家桶的成员是:vue-cli,vuex,vue-router,vue-axios(vue2.0)。
第三方插件:vue-scroller,vue-lazyload,vue-awesome-swiper(轮播插件)等等的。
---------------------------------------------------------------------------------
element-ui:作用切换主题,给其换肤
mint-ui:由饿了么前端团队推出的 Mint UI 是一个基于 Vue.js 的移动端组件库
vue-scroller:谁需要进行上拉加载下拉刷新就给谁加
vue-router是Vue.js官方的路由插件,路由用于设定访问路径,并将路径和组件映射起来。
 
vue-axios:请求后台接口.:发起http请求
vue-resource:请求后台接口
 
vue-cli脚手架构建工具打开命令行工具输入:npm install vue-cli -g,使用vue-cli来构建项目(帮你提供好基本项目结构)
 
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。实现不同组件之间的状态共享
每一个 Vuex 应用的核心就是 store(仓库)。“store”基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。
 
vue-loader 是一个 webpack 的 loader,可以将用下面这个格式编写的 Vue 组件转换为 JavaScript 模块
 
webpack 是一个模块打包工具。它将一堆文件中的每个文件都作为一个模块,找出它们的依赖关系,将它们打包为可部署的静态资源。(App.vue -> 变成正常代码 )
----------------------------------------------------------------------------------------------------------------------------
 
 
 
----------------------------------------------------------------------------------------------------------------------------
 
 
----------------------------------------------------------------------------------------------------------------------
技术分享图片
技术分享图片 
(从其他网址转载的这个图片,见谅)
---------------------------------------------------------------------------------------------------
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
var vm = new Vue({ // 选项 })
 
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
 
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例子如下
<script type="text/javascript">
// 我们的数据对象
var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
var vm = new Vue({
el: ‘#vue_det‘,
data: data
})
 
document.write(vm.$data === data) // true
document.write("<br>") // true
document.write(vm.$el === document.getElementById(‘vue_det‘)) // true
</script>
 
el:‘#box‘,//el 是选择器. 是挂载点,接下来的改动全部在以上指定的 div 内,div 外部不受影响。
data 用于定义属性
methods 用于定义的函数,可以通过 return 来返回函数值。
v-model :一般表单元素(input) 双向数据绑定
v-for ="value in a arrar": 循环数组
v-for="value in json" :循环json
{{value}} 值 ; {{$index}} 序号; {{$key}} key值。{{ }} 用于输出对象属性和函数返回值。数据绑定最常见的形式就是使用 {{...}}(双大括号)的文本插值:
v-on:click="show()" : 单击事件
显示隐藏:v-show=“true/false”
使用 v-html 指令用于输出 html 代码
v-bind : HTML 属性中的值应使用 v-bind 指令。
.缩写
v-bind 缩写
Vue.js 为两个最为常用的指令提供了特别的缩写:
<!-- 完整语法 --> <a v-bind:href="url"></a> <!-- 缩写 --> <a :href="url"></a>
v-on 缩写
<!-- 完整语法 --> <a v-on:click="doSomething"></a> <!-- 缩写 --> <a @click="doSomething"></a>
指令是带有 v- 前缀的特殊属性。
 
computed
计算属性关键词: computed。
计算属性在处理一些复杂逻辑时是很有用的。
 
watch 监听属性
 
Component 组件可以扩展 HTML 元素,封装可重用的代码。
注册一个全局组件语法格式如下:
Vue.component(tagName, options)
prop 是父组件用来传递数据的一个自定义属性。
父组件的数据需要通过 props 把数据传给子组件,子组件需要显式地用 props 选项声明 "prop":
 
使用 $emit(eventName) 触发事件
 
----------------------------------------------------------------------------------------------------------
属性:
v-bind:src=""
width/height/title....
 
简写:
:src="" 推荐
 
<img src="{{url}}" > 效果能出来,但是会报一个404错误
<img v-bind:src="url" > 效果可以出来,不会发404请求
 
------------------------------------------------------------------------------
class和style:
:class="" v-bind:class=""
:style="" v-bind:style=""
 
:class="[red]" red是数据
:class="[red,b,c,d]"
 
:class="{red:a, blue:false}"
 
:class="json"
 
data:{
json:{red:a, blue:false}
}
--------------------------
style:
:style="[c]"
:style="[c,d]"
注意: 复合样式,采用驼峰命名法
:style="json"
---------------------------------------------------------------------------------------------------
过滤器:-> 过滤模板数据
系统提供一些过滤器:
 
{{msg| filterA}}
{{msg| filterA | filterB}}
 
uppercase eg: {{‘welcome‘| uppercase}}
lowercase
capitalize
 
currency 钱
 
{{msg| filterA 参数}}
 
....
-----------------------------------------
-----------------------------------------
交互:
$http (ajax)
 
如果vue想做交互
 
引入: vue-resouce
 
get:
获取一个普通文本数据:
this.$http.get(‘aa.txt‘).then(function(res){
alert(res.data);
},function(res){
alert(res.status);
});
给服务发送数据:√
this.$http.get(‘get.php‘,{
a:1,
b:2
}).then(function(res){
alert(res.data);
},function(res){
alert(res.status);
});
post:
this.$http.post(‘post.php‘,{
a:1,
b:20
},{
emulateJSON:true
}).then(function(res){
alert(res.data);
},function(res){
alert(res.status);
});
jsonp:
https://sug.so.360.cn/suggest?callback=suggest_so&word=a
 
https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=a&cb=jshow
 
this.$http.jsonp(‘https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su‘,{
wd:‘a‘
},{
jsonp:‘cb‘ //callback名字,默认名字就是"callback"
}).then(function(res){
alert(res.data.s);
},function(res){
alert(res.status);
});
 
-----------------------------------------
交互:
$http (ajax)
 
如果vue想做交互
 
引入: vue-resouce
 
get:
获取一个普通文本数据:
this.$http.get(‘aa.txt‘).then(function(res){
alert(res.data);
},function(res){
alert(res.status);
});
给服务发送数据:√
this.$http.get(‘get.php‘,{
a:1,
b:2
}).then(function(res){
alert(res.data);
},function(res){
alert(res.status);
});
post:
this.$http.post(‘post.php‘,{
a:1,
b:20
},{
emulateJSON:true
}).then(function(res){
alert(res.data);
},function(res){
alert(res.status);
});
jsonp:
https://sug.so.360.cn/suggest?callback=suggest_so&word=a
 
https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=a&cb=jshow
 
this.$http.jsonp(‘https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su‘,{
wd:‘a‘
},{
jsonp:‘cb‘ //callback名字,默认名字就是"callback"
}).then(function(res){
alert(res.data.s);
},function(res){
alert(res.status);
});
 
 
---------------------------------------------------------------------------------------
页面的跳转:
<router-link to="/product/24" class="col-50">
<img src="/static/images/product-1.jpg" class="img-responsive"/>
<p>马来西亚浓缩金丝燕窝</p>
<span class="red">¥123元</span>
</router-link>
 
在router.js文件如下:
import Product from ‘./views/product.vue‘
 
{
path: ‘/product/:productId‘,
name: ‘product‘,
component: Product
}
 
 
 
-----------------------------------------------------------------------------------------------------
vue生命周期:
钩子函数:
 
created -> 实例已经创建 √
beforeCompile -> 编译之前
compiled -> 编译之后
ready -> 插入到文档中 √
 
beforeDestroy -> 销毁之前
destroyed -> 销毁之后
----------------------------------
用户会看到花括号标记:
 
v-cloak 防止闪烁, 比较大段落
----------------------------------
<span>{{msg}}</span> -> v-text
{{{msg}}} -> v-html
----------------------------------
ng: $scope.$watch
 
计算属性的使用:
computed:{
b:function(){ //默认调用get
return 值
}
}
--------------------------
computed:{
b:{
get:
set:
}
}
 
* computed里面可以放置一些业务逻辑代码,一定记得return
---------------------------------
vue实例简单方法:
vm.$el -> 就是元素
vm.$data -> 就是data
vm.$mount -> 手动挂在vue程序
 
vm.$options -> 获取自定义属性
vm.$destroy -> 销毁对象
 
vm.$log(); -> 查看现在数据的状态
---------------------------------
循环:
v-for="value in data"
 
会有重复数据?
track-by=‘索引‘ 提高循环性能
 
track-by=‘$index/uid‘
---------------------------------
---------------------------------
过滤器:
vue提供过滤器:
capitalize uppercase currency....
 
debounce 配合事件,延迟执行
数据配合使用过滤器:
limitBy 限制几个
limitBy 参数(取几个)
limitBy 取几个 从哪开始
 
filterBy 过滤数据
filterBy ‘谁’
 
orderBy 排序
orderBy 谁 1/-1
1 -> 正序
2 -> 倒序
 
自定义过滤器: model ->过滤 -> view
Vue.filter(name,function(input){
 
});
 
时间转化器
过滤html标记
 
双向过滤器:*
Vue.filter(‘filterHtml‘,{
read:function(input){ //model-view
return input.replace(/<[^<+]>/g,‘‘);
},
write:function(val){ //view -> model
return val;
}
});
 
数据 -> 视图
model -> view
 
view -> model
---------------------------------
v-text
v-for
v-html
指令: 扩展html语法
 
自定义指令:
属性:
 
Vue.directive(指令名称,function(参数){
this.el -> 原生DOM元素
});
 
<div v-red="参数"></div>
 
指令名称: v-red -> red
 
* 注意: 必须以 v-开头
 
拖拽:
-------------------------------
自定义元素指令:(用处不大)
Vue.elementDirective(‘zns-red‘,{
bind:function(){
this.el.style.background=‘red‘;
}
});
------------------------------------------------
引入 vue.js
-------------------------------------
bower-> (前端)包管理器 解决js的依赖管理 一款包管理工具
npm install bower -g
验证: bower --version
 
bower install <包名>
bower uninstall <包名>
bower info <包名> 查看包版本信息
 
<script src="bower_components/vue/dist/vue.js"></script>
-------------------------------------
vue-> 过渡(动画)
本质走的css3: transtion ,animation
 
<div id="div1" v-show="bSign" transition="fade"></div>
 
动画:
.fade-transition{
 
}
进入:
.fade-enter{
opacity: 0;
}
离开:
.fade-leave{
opacity: 0;
transform: translateX(200px);
}
 
另外的:引入Animate.css也可以实现动画
技术分享图片
----------------------------------------
 技术分享图片
 
----------------------------------------
vue组件:
组件: 一个大对象
定义一个组件:
1. 全局组件
var Aaa=Vue.extend({
template:‘<h3>我是标题3</h3>‘
});
 
Vue.component(‘aaa‘,Aaa);
 
*组件里面放数据:
data必须是函数的形式,函数必须返回一个对象(json)
2. 局部组件
放到某个组件内部
var vm=new Vue({
el:‘#box‘,
data:{
bSign:true
},
components:{ //局部组件
aaa:Aaa
}
});
--------------------------------------
另一种编写方式:
Vue.component(‘my-aaa‘,{
template:‘<strong>好</strong>‘
});
 
var vm=new Vue({
el:‘#box‘,
components:{
‘my-aaa‘:{
template:‘<h2>标题2</h2>‘
}
}
});
-----------------------------------
-----------------------------------
配合模板:
1. template:‘<h2 @click="change">标题2->{{msg}}</h2>‘
 
2. 单独放到某个地方
a). <script type="x-template" id="aaa">
<h2 @click="change">标题2->{{msg}}</h2>
</script>
b). <template id="aaa">
<h1>标题1</h1>
<ul>
<li v-for="val in arr">
{{val}}
</li>
</ul>
</template>
-----------------------------------
动态组件:
<component :is="组件名称"></component>
--------------------------------------------
vue-devtools -> 调试工具
https://chrome.google.com/webstore/detail/vuejs-devtools/nhdogjmejiglipccpnnnanhbledajbpd
--------------------------------------------
vue默认情况下,子组件也没法访问父组件数
 
--------------------------------------------
组件数据传递: √
1. 子组件就想获取父组件data
在调用子组件:
<bbb :m="数据"></bbb>
 
子组件之内:
props:[‘m‘,‘myMsg‘]
 
props:{
‘m‘:String,
‘myMsg‘:Number
}
2. 父级获取子级数据
*子组件把自己的数据,发送到父级
 
vm.$emit(事件名,数据);
 
v-on: @
--------------------------------------------
vm.$dispatch(事件名,数据) 子级向父级发送数据
vm.$broadcast(事件名,数据) 父级向子级广播数据
配合: event:{}
 
在vue2.0里面已经,报废了
--------------------------------------------
slot:
位置、槽口
作用: 占个位置
 
类似ng里面 transclude (指令)
 
--------------------------------------------
vue-> SPA应用,单页面应用
vue-resouce 交互
vue-router 路由
 
根据不同url地址,出现不同效果
 
咱上课: 0.7.13
 
主页 home
新闻页 news
 
 
html:
<a v-link="{path:‘/home‘}">主页</a> 跳转链接
 
展示内容:
<router-view></router-view>
js:
//1. 准备一个根组件
var App=Vue.extend();
 
//2. Home News组件都准备
var Home=Vue.extend({
template:‘<h3>我是主页</h3>‘
});
 
var News=Vue.extend({
template:‘<h3>我是新闻</h3>‘
});
 
//3. 准备路由
var router=new VueRouter();
 
//4. 关联
router.map({
‘home‘:{
component:Home
},
‘news‘:{
component:News
}
});
 
//5. 启动路由
router.start(App,‘#box‘);
 
跳转:
router.redirect({
‘/’:‘/home‘
});
--------------------------------------
路由嵌套(多层路由):
 
主页 home
登录 home/login
注册 home/reg
新闻页 news
 
subRoutes:{
‘login‘:{
component:{
template:‘<strong>我是登录信息</strong>‘
}
},
‘reg‘:{
component:{
template:‘<strong>我是注册信息</strong>‘
}
}
}
路由其他信息:
/detail/:id/age/:age
 
{{$route.params | json}} -> 当前参数
 
{{$route.path}} -> 当前路径
 
{{$route.query | json}} -> 数据
--------------------------------------------
vue-loader:
其他loader -> css-loader、url-loader、html-loader.....
 
 
 
 
后台: nodeJs -> require exports
broserify 模块加载,只能加载js
webpack 模块加载器, 一切东西都是模块, 最后打包到一块了
 
require(‘style.css‘); -> css-loader、style-loader
 
 
vue-loader基于webpack
 
.css
.js
.html
.php
.....
 
 
a.vue
b.vue
 
.vue文件:
放置的是vue组件代码
 
<template>
html
</template>
 
<style>
css
</style>
 
<script>
js (平时代码、ES6) babel-loader
</script>
-------------------------------------
简单的目录结构:
|-index.html
|-main.js 入口文件
|-App.vue vue文件,官方推荐命名法
|-package.json 工程文件(项目依赖、名称、配置)
npm init --yes 生成
|-webpack.config.js webpack配置文件
 
ES6: 模块化开发
导出模块:
export default {}
引入模块:
import 模块名 from 地址
--------------------------------------------
 
webpak准备工作:
cnpm install webpack --save-dev
cnpm install webpack-dev-server --save-dev
 
App.vue -> 变成正常代码 vue-loader@8.5.4
cnpm install vue-loader@8.5.4 --save-dev
 
cnpm install vue-html-loader --save-dev
 
vue-html-loader、css-loader、vue-style-loader、
vue-hot-reload-api@1.3.2
 
babel-loader
babel-core
babel-plugin-transform-runtime
babel-preset-es2015
babel-runtime
--------------------------------------------
手动配置自己:
webpack+vue-loader
 
webpack加载模块
-------------------------------------
如何运行此项目?
1. npm install 或者 cnpm install
2. npm run dev
-> package.json
"scripts":{
"dev":"webpack-dev-server --inline --hot --port 8082"
}
 
以后下载模块:
npm install <package-name> --save-dev
 
EADDRINUSE 端口被占用
 
少了:
webpack-dev-server
webpack
----------------------------------------
.vue 结尾,之后称呼组件
----------------------------------------
路由:
vue-router
 
-> 如何查看版本:
bower info vue-router
 
路由使用版本: 0.7.13
配合vue-loader使用:
1. 下载vue-router模块
cnpm install vue-router@0.7.13
2. import VueRouter from ‘vue-router‘
 
3. Vue.use(VueRouter);
 
4. 配置路由
var router=new VueRouter();
router.map({
路由规则
})
5. 开启
router.start(App,‘#app‘);
 
注意:
之前: index.html -> <app></app>
现在: index.html -> <div id="app"></div>
 
App.vue -> 需要一个 <div id="app"></div> 根元素
 
home news
---------------------------------------------
路由嵌套:
和之前一模一样
--------------------------------------------
上线:
npm run build
-> webpack -p
--------------------------------------------
脚手架:
vue-cli——vue脚手架
帮你提供好基本项目结构
 
本身集成很多项目模板:
simple 个人觉得一点用都没有
webpack 可以使用(大型项目)
Eslint 检查代码规范,
单元测试
webpack-simple 个人推荐使用, 没有代码检查 √
 
browserify -> 自己看
browserify-simple
 
--------------------------------------------
基本使用流程:
1. npm install vue-cli -g 安装 vue命令环境
验证安装ok?
vue --version
2. 生成项目模板
vue init <模板名> 本地文件夹名称
3. 进入到生成目录里面
cd xxx
npm install
4. npm run dev
--------------------------------------------
vue2.0:
bower info vue
 
http://vuejs.org/
到了2.0以后,有哪些变化?
 
1. 在每个组件模板,不在支持片段代码
组件中模板:
之前:
<template>
<h3>我是组件</h3><strong>我是加粗标签</strong>
</template>
现在: 必须有根元素,包裹住所有的代码
<template id="aaa">
<div>
<h3>我是组件</h3>
<strong>我是加粗标签</strong>
</div>
</template>
2. 关于组件定义
Vue.extend 这种方式,在2.0里面有,但是有一些改动,这种写法,即使能用,咱也不用——废弃
 
Vue.component(组件名称,{ 在2.0继续能用
data(){}
methods:{}
template:
});
 
2.0推出一个组件,简洁定义方式:
var Home={
template:‘‘ -> Vue.extend()
};
---------------------------------------------------------------------------
3. 生命周期
之前:
init
created
beforeCompile
compiled
ready √ -> mounted
beforeDestroy
destroyed
现在:
beforeCreate 组件实例刚刚被创建,属性都没有
created 实例已经创建完成,属性已经绑定
beforeMount 模板编译之前
mounted 模板编译之后,代替之前ready *
beforeUpdate 组件更新之前
updated 组件更新完毕 *
beforeDestroy 组件销毁前
destroyed 组件销毁后
3. 循环
2.0里面默认就可以添加重复数据
 
arr.forEach(function(item,index){
 
});
 
去掉了隐式一些变量
$index $key
 
之前:
v-for="(index,val) in array"
现在:
v-for="(val,index) in array"
 
 
4. track-by="id"
变成
<li v-for="(val,index) in list" :key="index">
5. 自定义键盘指令
之前:Vue.directive(‘on‘).keyCodes.f1=17;
 
现在: Vue.config.keyCodes.ctrl=17
6. 过滤器
之前:
系统就自带很多过滤
{{msg | currency}}
{{msg | json}}
....
limitBy
filterBy
.....
一些简单功能,自己通过js实现
 
到了2.0, 内置过滤器,全部删除了
 
 
lodash 工具库 _.debounce(fn,200)
 
 
自定义过滤器——还有
但是,自定义过滤器传参
 
之前: {{msg | toDou ‘12‘ ‘5‘}}
现在: {{msg | toDou(‘12‘,‘5‘)}}
------------------------------------------------------
------------------------------------------------------
组件通信:
vm.$emit()
vm.$on();
 
父组件和子组件:
 
子组件想要拿到父组件数据:
通过 props
 
之前,子组件可以更改父组件信息,可以是同步 sync
现在,不允许直接给父级的数据,做赋值操作
 
问题,就想更改:
a). 父组件每次传一个对象给子组件, 对象之间引用 √
b). 只是不报错, mounted中转
------------------------------------------------------
可以单一事件管理组件通信: vuex
var Event=new Vue();
 
Event.$emit(事件名称, 数据)
 
Event.$on(事件名称,function(data){
//data
}.bind(this));
------------------------------------------------------
debounce 废弃
-> lodash
_.debounce(fn,时间)
------------------------------------------------------
vue动画
vue路由
--------------------------------------
transition 之前 属性
<p transition="fade"></p>
 
.fade-transition{}
.fade-enter{}
.fade-leave{}
--------------------------------------
 
到2.0以后 transition 组件
 
<transition name="fade">
运动东西(元素,属性、路由....)
</transition>
 
class定义:
.fade-enter{} //初始状态
.fade-enter-active{} //变化成什么样 -> 当元素出来(显示)
 
.fade-leave{}
.fade-leave-active{} //变成成什么样 -> 当元素离开(消失)
 
如何animate.css配合用?
<transition enter-active-class="animated zoomInLeft" leave-active-class="animated zoomOutRight">
<p v-show="show"></p>
</transition>
 
多个元素运动:
<transition-group enter-active-class="" leave-active-class="">
<p :key=""></p>
<p :key=""></p>
</transition-group>
------------------------------------------
vue2.0 路由:
http://router.vuejs.org/zh-cn/index.html
 
下载:bower install vue-router
基本使用:
1. 布局
<router-link to="/home">主页</router-link>
 
<router-view></router-view>
2. 路由具体写法
//组件
var Home={
template:‘<h3>我是主页</h3>‘
};
var News={
template:‘<h3>我是新闻</h3>‘
};
 
//配置路由
const routes=[
{path:‘/home‘, componet:Home},
{path:‘/news‘, componet:News},
];
 
//生成路由实例
const router=new VueRouter({
routes
});
 
//最后挂到vue上
new Vue({
router,
el:‘#box‘
});
3. 重定向
之前 router.rediect 废弃了
{path:‘*‘, redirect:‘/home‘}
------------------------------------------
------------------------------------------
路由嵌套:
/user/username
 
const routes=[
{path:‘/home‘, component:Home},
{
path:‘/user‘,
component:User,
children:[ //核心
{path:‘username‘, component:UserDetail}
]
},
{path:‘*‘, redirect:‘/home‘} //404
];
------------------------------------------
传参数:
/user/strive/age/10
:id
:username
:age
---------------------------------------
路由实例方法:
router.push({path:‘home‘}); //直接添加一个路由,表现切换路由,本质往历史记录里面添加一个
router.replace({path:‘news‘}) //替换路由,不会往历史记录里面添加
------------------------------------------
vue-cli
------------------------------------------
npm install
命令:vue init webpack-simple vue-demo
------------------------------------------
脚手架: vue-loader
1.0 ->
new Vue({
el: ‘#app‘,
components:{App}
})
2.0->
new Vue({
el: ‘#app‘,
render: h => h(App)
})
------------------------------------------
vue2.0
vue-loader和vue-router配合
vue-router安装:cnpm install vue-router --save
------------------------------------------
 
style-loader css-loader
 
style!css
命令:cnpm install css-loader style-loader --save-dev
------------------------------------------
vue问题:
论坛
http://bbs.zhinengshe.com
------------------------------------------------
-------------------------------------------------
UI组件
别人提供好一堆东西
 
目的:
为了提高开发效率
功能
 
原则: 拿过来直接使用
 
vue-cli -> vue-loader
 
bootstrap:
twitter 开源
简洁、大方
官网文档
 
基于 jquery
 
栅格化系统+响应式工具 (移动端、pad、pc)
按钮
--------------------------------
bower 前端包管理器 jquery#1.11.1
自动解决依赖
npm node包管理器 jquery@1.11.1
--------------------------------
 
饿了么团队开源一个基于vue 组件库
elementUI PC
MintUI 移动端
--------------------------------
elementUI:
如何使用
 
官网:http://element.eleme.io/
使用:
1. 安装 element-ui
npm i element-ui -D
 
npm install element-ui --save-dev
 
// i -> install
// D -> --save-dev
// S -> --save
2. 引入 main.js 入口文件
import ElementUI from ‘element-ui‘
import ‘element-ui/lib/theme-default/index.css‘
 
全部引入
3. 使用组件
Vue.use(ElementUI)
 
css-loader 引入css
字体图标 file-loader
 
 
less:
less
less-loader
-------------------------------------------------
按需加载相应组件: √
就需要 按钮
1. babel-plugin-component
cnpm install babel-plugin-component -D
2. .babelrc文件里面新增一个配置
"plugins": [["component", [
{
"libraryName": "element-ui",
"styleLibraryName": "theme-default"
}
]]]
3. 想用哪个组件就用哪个
引入:
import {Button,Radio} from ‘element-ui‘
使用:
a). Vue.component(Button.name, Button); 个人不太喜欢
b). Vue.use(Button); √
---------------------------------------------------
发送请求:
vue-resourse 交互
 
axios
---------------------------------------------------
element-ui -> pc
 
mint-ui
移动端 ui库
 
http://mint-ui.github.io/
 
1. 下载
npm install mint-ui -S
 
-S
--save
2. 引入
import Vue from ‘vue‘;
import Mint from ‘mint-ui‘;
import ‘mint-ui/lib/style.css‘
Vue.use(Mint);
 
按需引入:
import { Cell, Checklist } from ‘minu-ui‘;
Vue.component(Cell.name, Cell);
Vue.component(Checklist.name, Checklist);
 
http://mint-ui.github.io/docs/#!/zh-cn2
 
论坛:
 
-------------------------------------------------------
 
Mint-ui-demo: 看着手册走了一遍
 
 
 
技术分享图片
 技术分享图片
 
技术分享图片
 技术分享图片
技术分享图片
 技术分享图片
 
1. 下载
npm install mint-ui -S
 
-S
--save
2. 引入
import Vue from ‘vue‘;
import Mint from ‘mint-ui‘;
import ‘mint-ui/lib/style.css‘
Vue.use(Mint);
 
按需引入:
import { Cell, Checklist } from ‘minu-ui‘;
Vue.component(Cell.name, Cell);
Vue.component(Checklist.name, Checklist);
 
http://mint-ui.github.io/docs/#!/zh-cn2
技术分享图片
技术分享图片 
技术分享图片
技术分享图片
cnpm install babel-loader
 
在项目开发的时候,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用vue-cli进行项目打包的时候,我们在本地启动服务器后,比如本地开发服务下是 http://localhost:8080 这样的访问页面,但是我们的接口地址是 http://xxxx.com/save/index 这样的接口地址,我们这样直接使用会存在跨域的请求,导致接口请求不成功,因此我们需要在打包的时候配置一下,我们进入 config/index.js 代码下如下配置即可:
技术分享图片
dev: { // 静态资源文件夹 assetsSubDirectory: ‘static‘, // 发布路径 assetsPublicPath: ‘/‘, // 代理配置表,在这里可以配置特定的请求代理到对应的API接口 // 例如将‘localhost:8080/api/xxx‘代理到‘www.example.com/api/xxx‘ // 使用方法:https://vuejs-templates.github.io/webpack/proxy.html proxyTable: { ‘/api‘: { target: ‘http://xxxxxx.com‘, // 接口的域名 // secure: false, // 如果是https接口,需要配置这个参数 changeOrigin: true, // 如果接口跨域,需要进行这个参数配置 pathRewrite: { ‘^/api‘: ‘‘ } } }, // 本地访问 http://localhost:8080 host: ‘localhost‘, // can be overwritten by process.env.HOST
技术分享图片
接口地址原本是 /save/index,但是为了匹配代理地址,在前面加一个 /api,  因此接口地址需要写成这样的即可生效 /api/save/index。
注意: ‘/api‘ 为匹配项,target 为被请求的地址,因为在 ajax 的 url 中加了前缀 ‘/api‘,而原本的接口是没有这个前缀的,所以需要通过 pathRewrite 来重写地址,将前缀 ‘/api‘ 转为 ‘/‘。如果本身的接口地址就有 ‘/api‘ 这种通用前缀,就可以把 pathRewrite 删掉。
 
render: h => h(App)
 
{ render: h => h(App); }
等价于
{ render: h => { return h(App); } }
等价于
{ render: function(h) { return h(App); } }
即:
{ render: function(createElement) { return createElement(App); } }
看了 createElement 的官方文档,其实我还是不明白 createElement 的用法的。createElement 方法的参数有几个?各个参数的含义、类型是什么?
示例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"></div> <script type="text/javascript" src="https://unpkg.com/vue"></script> <script type="text/javascript"> var app = new Vue({ el: ‘#app‘, // 提供一个在页面上已经存在的 DOM 元素作为 Vue 实例挂载目标 render: function (createElement) { return createElement(‘h2‘, ‘Hello Vue!‘); } }); </script> </body> </html>
 
<keep-alive>
是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM。
 
methods是个方法,比如你点击事件要执行一个方法,这时候就用methods,
computed是计算属性,实时响应的,比如你要根据data里一个值随时变化做出一些处理,就用computed。
 
Vue.prototype
作用:定义全局变量、定义全局函数
定义全局变量: 用export default 暴露出去,在main.js里面使用Vue.prototype挂载到vue实例上面或者在其它地方需要使用时,引入该模块便可。
定义全局函数:在main.js里面通过Vue.prototype将函数挂载到Vue实例上面,通过this.函数名,来运行函数。
 
sessionStorage
通过sessionStorage实现在Vue中多个页面间的变量的保存与读取
如在登录成功后,我们将用户名保存在sessionStorage中
sessionStorage.setItem(‘userName‘, res.data.userName);
在其他页面,我们通过sessionStorage取出用户名
var userName = sessionStorage.getItem(‘userName‘);
 
如何用JS判断是苹果客户端还是安卓客户端:
if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) {
//alert(navigator.userAgent);
window.location.href ="iPhone.html";
} else if (/(Android)/i.test(navigator.userAgent)) {
//alert(navigator.userAgent);
window.location.href ="Android.html";
} else {
window.location.href ="pc.html";
};
 
navigator.userAgent
声明了浏览器用于 HTTP 请求的用户代理头的值
 
挂载数据
在实例化Vue的时候,两种方式挂载数据
方法一:最常用的方法
var app=new vue({
el:"#app",
data(){}
`````
})
注:文档中最常用的做法就是直接在实例化的时候利用el:"#app"来挂载元素
方法二:$mount 
var app=new vue({
data(){}
})
app.$mount("#app")
注:利用$mount挂载的方法有一个很大的好处,就是将实例化的内容和他对HTML的关联分开,可以更直观的展现。
 
require(‘qs‘)
使用qs库来格式化数据
var qs = require(‘qs‘); axios.post(‘/foo‘, qs.stringify({‘bar‘:123}));
 
 
 
 

VueJs学习笔记

标签:http请求   document   马来西亚   tail   static   数据绑定   serve   under   实例   

原文地址:https://www.cnblogs.com/SharkBin/p/8971367.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!