您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

vue2全家桶是什么,如何使用?

2024/12/7 4:30:52发布16次查看
这次给大家带来vue2全家桶是什么,如何使用?,vue2全家桶是什么?使用的注意事项有哪些,下面就是实战案例,一起来看一下。
都说vue2简单,上手容易,但小马过河,自己试了才晓得,除了es6语法和webpack的配置让你感到陌生,重要的是思路的变换,以前随便拿全局变量和修改dom的锤子不能用了,变换到关注数据本身。vue的官方文档还是不错的,由浅到深,但是当你用vue-cli构建一个工程的时候,发现官方文档还是不够用,得参考git上开源的项目并去学习es6。而且vue的全家桶(vue-cli,vue-router,vue-resource,vuex)还是都要上的。
1.vue-cli这个构建工具大大降低了webpack的使用难度,支持热更新,有webpack-dev-server的支持,相当于启动了一个请求服务器,给你搭建了一个测试环境,你只关注开发就好。
# 全局安装 vue-cli $ npm install --global vue-cli # 创建一个基于 webpack 模板的新项目 $ vue init webpack my-project # 安装依赖,走你 $ cd my-project $ npm install $ npm run dev
热更新的机制是检测文件的变化并用websocket通知客户端做出相应的更新。详细的可以移步:【webpack】-- 模块热替换
2.vue-routervue的路由还是很方便的,比ag1的时候要方便很多。这种方便体现在三个方面:
1个是路由和页面(组件)对应:
import vue from 'vue'import router from 'vue-router'import home from '@/components/home'import chat from '@/components/chat'import firends from '@/components/firends'import logon from '@/components/logon'vue.use(router) let router=new router({   routes: [     {       path: '/home',       name: 'home',       component: home     },      { path: '/', redirect: '/home' },//重定向     {       path: '/chat',       name: 'chat',       component: chat     },     {       path: '/firends',       name: 'firends',       component: firends     },     {       path: '/logon',       name: 'logon',       component: logon     }   ] });
常人的思路就是这样,而ag1中还需要带上控制器(vue中没有这个概念,取而代之的是关注组件就行),这样用起来更简单。mvc模式中,需要指到controller下的action,如果导航分类多,对应策略是嵌套路由。
2个是可以具体到元素了:
<router-link class="footer-item" exact to="home">首页</router-link>
这个to后面的home(忽略大小写)就是上面定义的路由名称。这样就很方便了。类似于asp.net mvc 的路由可以用名称来渲染出路径,而不用什么时候都要输入路径。
3个是事件拦截:
如果我们要做验证,最好不过的就是在用户到达页面之前进行验证:
router.beforeeach((to, from, next) => {  //todo 以后增加不需要验证的地址判断   if(to.path!==/logon&&!store.state.userinfo.account){      next({ path: '/logon' })     return;   }else{    next();   }  })
比如在beforeeach中进行处理。它还有很多功能,就不一一枚举了,官方文档:http://router.vuejs.org/zh-cn/
3.组件中使用组件看了几个移动ui库,一开始奇怪怎么没有footer组件,现在明白,路由都这么方便了,第三方ui没必要封装了footer,也不方便封装(因为依赖路由)。于是导航可能是你需要自己来写的第一个组件。
比如定义了个footer.vue
首页                                 统计                                   更多
<script>
export default {
name: 'vfooter'
}
</script>
只在app.vue中就需要引入
import vfooter from './vfooter'  export default { name: 'app', data () {return { msg: 'this is home'} },components:{vfooter}}
然后在app.vue中就可以使用了
<vfooter></vfooter>
如果是要注册到全局 就用先在main.js中引入
import footer from './components/vfooter'//vue.component('vfooter', footer)//写在构造函数之前
到了这一步就可以愉快的组装自己的页面了。如果需要给页面加上滑动效果,可以加一个transition(位于app.vue):
<transition name="slide-in" mode="out-in">     <router-view></router-view>    </transition>
.slide-out-enter-active, .slide-out-leave-active, .slide-in-enter-active, .slide-in-leave-active {   will-change: transform;   transition: all 400ms;   position: absolute; }.slide-out-enter {   opacity: 0;    transform: translatex(-100%);    }.slide-out-leave-active {   opacity: 0;    transform: translatex(100%);    }.slide-in-enter {   opacity: 0;    transform: translatex(100%); }.slide-in-leave-active {   opacity: 0;    transform: translatex(-100%);
如何做到左右切换呢?
4.vue-resource页面敲好了,得能发请求。https://github.com/pagekit/vue-resource 而前端如果不是自己写的接口首先关心的还是怎么设置代理,这个位于config/index.js下面的proxytable。
proxytable: {    '/api':      {            target: 'http://11.111.249.12:11',           changeorigin: true,            pathrewrite:            {              '^/api': ''             }     },
跨域的设置不能少了changeorigin。另外需要注意最后的这个'^/api': ''。 要注意你选择的/api是不是原路径中的一部分,不然容易出错。
然后还有一部分就是设置请求头(main.js):
import vueresource from 'vue-resource'vue.use(vueresource); vue.http.interceptors.push(function(request, next) {// modify method   //request.method = 'post';   // modify headers         request.headers.set('token',“token”);// continue to next interceptor  next(); });
5.vuex全家桶里面一开始最让我懵逼的就是这个vuex。这是个什么鬼,为什么需要这个。没有玩过react,不知道什么是状态管理。当你想用一个全局变量的时候,你发现之前的招都不灵了。比如设置一个登录状态
let login=(name,pwd,success,fail)=>}).then(res=>
然后再首页显示出来:
<p @click="toggle">{{haslogin}}</p>
data () {    return {       haslogin:window.haslogin     }   },    methods:{      toggle(){        window.haslogin=!window.haslogin;        console.log(clicked,window.haslogin)      }    },
你发现你登录之后确实显示了true,但怎么点击也不会切换false或true。
需要再赋值一次:
this.haslogin=window.haslogin;
为什么呢?因为你自己定义的变量,根本不属于vue的model。也就是没有处理过geter和seter,虽然变量的值是变化了,但仍然无法改变界面上的状态。所以你需要一个状态管理,按照一定的机制把你的变量变换成vue内部的模型。这个东西就是vuex。因为约定比较多,略显复杂点,但是耐心看一下还是很容易接受的。它主要分四个部分,state,getters,mutations,actions。先定义一个user.js如下:
state就是我们放共享变量的地方。比如下面的userinfo.
import vue from 'vue'; import vuex from 'vuex'; vue.use(vuex); const userstore=new vuex.store({    state:{        userinfo:{            username:        }    },    getters:{        getuserinfo(state){           return state.userinfo;        }    },    mutations:{        setuserinfo(state,userinfo){            state.userinfo=userinfo;        }    },    actions:{        setuserinfo({commit}){            commit('setuserinfo');        }    } }) export default userstore;
而getters顾名思义就是获取接口,mutations(突变)这个词有点唬人,其实就是setters嘛。里面的方法自带state参数。而actions就是mutations的异步方法。然后再main.js中引用一下:
import store from './store/user';//...  new vue({   el: '#app',   router,  store,   template: '<app/>',   components: { app } })
然后我们在设置或获取的时候就可以使用指定的方法:
import store from '@/store/user'; //... store.commit('setuserinfo',user)
可以直接通过store.state获取变量,也可以通过getters接口:
computed:{   ...mapgetters({username:'getusername'})   },
这三个点是es6中的扩展运算符。将一个数组转为用逗号分隔的参数序列。
当然这些状态刷新之后就没有了,如果想要暂存下来,可以放到sessionstorage中:
if (window.sessionstorage.user) {    var json=json.parse(window.sessionstorage.user);     store.commit('setsessionuser',json)}
当然要在muations中放进去
==
官方文档: https://vuex.vuejs.org/zh-cn/
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
vue的自定义动态组件使用详解
protobuf.js 与 long.js的使用详解
让js自动匹配出proto js的方法
以上就是vue2全家桶是什么,如何使用?的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product