Vue 创建单页面程序

作为一个小公司的PHPER,不喜欢乌漆墨黑的命令行(老是报错,技术又不好找不到解决方法),研究了半天vue-click以后,选择了放弃,这里用vue创建一个单页面程序,不多说上代码!

引入vue相关的CDN,建议在https://www.bootcdn.cn/去找,

  1. vue.js的CDN https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.js
  2. vue的路由 https://cdn.bootcss.com/vue-router/3.0.1/vue-router.js
  3. vue状态管理vuex https://cdn.bootcss.com/vuex/3.0.1/vuex.js

html代码只有body 部分

<body>
    <div id="app">
        <div class="row">
            <div class="col-xs-offset-2 col-xs-8">
                <div class="page-header">
                    <h2>Router Test</h2>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-xs-2 col-xs-offset-2">
                <div class="list-group">
                    <!--使用指令v-link进行导航-->
                    <router-link to='/home' class="list-group-item"  >Home</router-link>
                    <router-link to='/about'  class="list-group-item"  >About</router-link>
                </div>
            </div>
            <div class="col-xs-6">
                <div class="panel">
                    <div class="panel-body">
                        <!--用于渲染匹配的组件-->
                        <router-view></router-view>
                    </div>
                </div>
            </div>
        </div>
    </div>
   // home路由部分
    <template id="home">
        <div>
            <h1 @click="_alert(123)">Home</h1>
            <p>{{num}}</p>
        </div>
    </template>
  // about路由部分
    <template id="about">
        <div>
            <h1>About</h1>
            <p>{{num}}</p>
        </div>
    </template>
</body>

js部分的代码

<script>
/* 创建一个vuex状态管理 */
/* 调用Vuex store 的方式只介绍两种  
* 同步的方式  store.commit('increment','需要传的参数')
* 异步的方式  store.dispatch('incrementAsync',{ amount: 10  })
* 直接在组件中使用就行
*/
const store = new Vuex.Store({
    state: {
        count: 5
    },
    mutations: {/*实际改变参数状态的方法*/
        increment (state, no) {
            state.count = Number(state.count) + Number(no)
        }
    },
    actions: {  /*按我的理解是在actions中调用mutations的方法increment实现异步传输给组件*/
        incrementAsync  (context,payload) {
            context.commit('increment',payload.amount)
        }
    }
})


/* 创建Home 组件构造器  */
const Home = Vue.extend({
    template: '#home',
    data: function () {
        return {
            msg: 'Hello, vue router!',
            num: ''
        }
    },
    methods:{
        _alert:function (e){
            store.dispatch('incrementAsync',{
                amount: 10
            }) /* 异步的方式调用vuex */
            this.num = store.state.count  /*获取vuex中count的值*/ 
            console.log( this.num )
        }
    },
    created:function(){
        this.num = store.state.count
        console.log( this.num ) // -> 1
    }
})

/* About 路由的组件*/
const About = Vue.extend({
    template: '#about',
    data: function () {
        return {
            msg: 'Hello, vue router6666666666!',
            num: store.state.count
        }
    },
    methods:{
        _alert:function(e){
            alert(e)
        }
    },
})

/* 创建路由映射  */
const routes = [
    { path: '/home', component: Home},
    { path: '/about', component: About },
    { path: '/', component: Home }
]

/* 创建路由器  */
var router = new VueRouter({
    routes
})

//  创建一个顶层的vue实例
const vm = new Vue({
  // el: 'body',
  router, //  路由
  components: { Home, About },
  template: '#app'
})

/* 启动路由  */
const app = new Vue({
    router
}).$mount('#app')
</script>

整个完整页面的代码

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css" />
</head>
<body>
    <div id="app">
        <div class="row">
            <div class="col-xs-offset-2 col-xs-8">
                <div class="page-header">
                    <h2>Router Basic - 01</h2>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-xs-2 col-xs-offset-2">
                <div class="list-group">
                    <!--使用指令v-link进行导航-->
                    <router-link to='/home' class="list-group-item"  >Home</router-link>
                    <router-link to='/about'  class="list-group-item"  >About</router-link>
                </div>
            </div>
            <div class="col-xs-6">
                <div class="panel">
                    <div class="panel-body">
                        <!--用于渲染匹配的组件-->
                        <router-view></router-view>
                    </div>
                </div>
            </div>
        </div>
    </div>
    <template id="home">
        <div>
            <h1 @click="_alert(123)">Home</h1>
            <p>{{num}}</p>
        </div>
    </template>
    <template id="about">
        <div>
            <h1>About</h1>
            <p>{{num}}</p>
        </div>
    </template>
</body>
<script src="./js/vue.js"></script>
<script src="./js/vue-router.js"></script>
<script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.js"></script>
<script>
const store = new Vuex.Store({
    state: {
        count: 5
    },
    mutations: {
        increment (state, no) {
            state.count = Number(state.count) + Number(no)
        }
    },
    actions: {
        incrementAsync  (context,payload) {
            context.commit('increment',payload.amount)
        }
    }
})

/* 创建组件构造器  */
const Home = Vue.extend({
    template: '#home',
    data: function () {
        return {
            msg: 'Hello, vue router!',
            num: ''
        }
    },
    methods:{
        _alert:function (e){
            store.dispatch('incrementAsync',{
                amount: 10
            })
            this.num = store.state.count
            console.log( this.num )
        }
    },
    created:function(){
        this.num = store.state.count
        console.log( this.num ) // -> 1
    }
})
/* About 路由的组件 */
const About = Vue.extend({
    template: '#about',
    data: function () {
        return {
            msg: 'Hello, vue router6666666666!',
            num: store.state.count
        }
    },
    methods:{
        _alert:function(e){
            alert(e)
        }
    },
})

/* 创建路由映射  */
const routes = [
    { path: '/home', component: Home},
    { path: '/about', component: About },
    { path: '/', component: Home }
]

/* 创建路由器  */
var router = new VueRouter({
    routes
})

const vm = new Vue({
  // el: 'body',
  router,
  components: { Home, About },
  template: '#app'
})

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

推荐阅读更多精彩内容