基于VUE实现的新闻后台管理系统-三

简介: 开始coding啦¶分析项目根据展示效果我们可以分析出,Web页面有两个,一个用于登录,一个用于系统内容控制,我们分别将其命名为Login和Cms,然后进行路由配置。在src/page下新建Login.

开始coding啦

¶分析项目

根据展示效果我们可以分析出,Web页面有两个,一个用于登录,一个用于系统内容控制,我们分别将其命名为Login和Cms,然后进行路由配置。

  1. 在src/page下新建Login.vue和Cms.vue文件,及进行vue模板构建



    |--src
    |--page
    |--Cms.vue
    |--Login.vue

    <template>
    </template>
    <script scope>
    </script>
    <style>
    </style>
  2. 将Login和Cms组件导入到/router/index.js中

    // import something....
    import Cms from '@/page/Cms'
    import Login from '@/page/Login'
  3. 修改路由配置,该配置在/src/router/index.js中;将如下代码

    routes: [
        {
        path: '/',
        name: 'Hello',
        component: Hello
        }
    ]

    修改为

    routes: [
        {
        path: '/cms', // 后台管理系统路由
        name: 'Cms',
        component: Cms
        },
        {
        path: '/', // 登录路由
        name: 'Login',
        component: Login
        }
    ]

    ¶内容实现

  4. 登录请求存储

    我们将登录状态存储在sessionStorage中,所以在/src下新建utils/index.js,并写入如下代码

        let KEY = 'USER'
        export default {
        /**
        *  set user info in sessionStorage
        * @param userInfo  Object   user info
        * @return none
        */
        setLoginState: (userInfo) => {
            window.sessionStorage.setItem(KEY, JSON.stringify(userInfo))
        },
        /**
        *  get user info from sessionStorage
        * @return userInfo Object  user Info
        */
        getLoginState: () => {
            return window.sessionStorage.getItem(KEY)
        },
        deleteLoginState: () => {
            return new Promise((resolve, reject) => {
            window.sessionStorage.removeItem(KEY) ? resolve({'isDelete': true}) : reject({'isDelete': false})
            })
        }
        }
  5. 整合Axios请求

    向后台请求数据,必须有像Ajax一样的请求,幸好在Node环境下有Axios这样的npm库封装了xhr这样的请求,这个库在上一节已经完成安装,为了在本系统中使用,且符合Vue开发规范,我们将其再次进行封装;在src目录下新建api/index.js文件,并写入如下代码

    // 配置API接口地址
    var root = '/api/v1'
    // 引用axios
    var axios = require('axios')
    // 自定义判断元素类型JS
    function toType (obj) {
    return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase()
    }
    // 参数过滤函数
    function filterNull (o) {
    for (var key in o) {
        if (o[key] === null) {
        delete o[key]
        }
        if (toType(o[key]) === 'string') {
        o[key] = o[key].trim()
        } else if (toType(o[key]) === 'object') {
        o[key] = filterNull(o[key])
        } else if (toType(o[key]) === 'array') {
        o[key] = filterNull(o[key])
        }
    }
    return o
    }
    /*
    接口处理函数
    这个函数每个项目都是不一样的,我现在调整的是适用于
    https://cnodejs.org/api/v1 的接口,如果是其他接口
    需要根据接口的参数进行调整。参考说明文档地址:
    https://cnodejs.org/topic/5378720ed6e2d16149fa16bd
    主要是,不同的接口的成功标识和失败提示是不一致的。
    另外,不同的项目的处理方法也是不一致的,这里出错就是简单的alert
    */
    
    function apiAxios (method, url, params, success, failure) {
    if (params) {
        params = filterNull(params)
    }
    axios({
        method: method,
        url: url,
        data: method === 'POST' || method === 'PUT' ? params : null,
        params: method === 'GET' || method === 'DELETE' ? params : null,
        baseURL: root,
        withCredentials: false
    })
    .then(function (res) {
        if (res.data.success === true) {
        if (success) {
            success(res.data)
        }
        } else {
        if (failure) {
            failure(res.data)
        } else {
            window.alert('error: ' + JSON.stringify(res.data))
        }
        }
    })
    .catch(function (err) {
        let res = err.response
        if (err) {
        window.alert('api error, HTTP CODE: ' + res.status ? res.status : null)
        return
        }
    })
    }
    
    // 返回在vue模板中的调用接口
    export default {
    get: function (url, params, success, failure) {
        return apiAxios('GET', url, params, success, failure)
    },
    post: function (url, params, success, failure) {
        return apiAxios('POST', url, params, success, failure)
    },
    put: function (url, params, success, failure) {
        return apiAxios('PUT', url, params, success, failure)
    },
    delete: function (url, params, success, failure) {
        return apiAxios('DELETE', url, params, success, failure)
    }
    }
  6. 登录Login.vue组件实现

    因为写的Vue不是纯Js,所以代码木有高亮

    <template>
        <div class='login'>
            <div class='loginPage' >
            <el-form class='loginForm' label-position='left' label-width="80px" >
                <el-input class='loginInput' placeholder="请输入内容" @change='usernameChange' >
                    <template slot="prepend">用户名</template>
                </el-input>
                <el-input class='loginInput' type='password' placeholder="请输入内容" @change='userPassChange' >
                    <template slot="prepend">密码</template>
                </el-input>
                <el-button class='loginBtn' type="primary" :disabled="isLoginBtnDisable" @click='login'>登录</el-button>
            </el-form>
            </div>
            <cms-footer :siteInfo='siteinfo'></cms-footer>
        </div>
        </template>
    
        <script>
        import CmsFooter from '../components/Footer'
        export default {
        data () {
            return {
            isLoginBtnDisable: true,
            username: null,
            userPass: null,
            siteinfo: {
                name: '',
                title: '',
                logo: '',
                copyright: ''
            }
            }
        },
        components: {
            'cms-footer': CmsFooter
        },
        created () {
            this.getSiteInfo()
        },
        methods: {
            refresh () {
            window.location.reload()
            },
            login (evt) {
            if (!this.isLoginBtnDisable) {
                let params = {
                account: this.username,
                password: this.userPass
                }
                this.$api.post('login', params, (errObj) => {
                console.log('login error', JSON.stringify(errObj))
                }, (resp) => {
                resp && resp.code === 0 ? this.setUserInfoToGo({account: this.username}) : null
                })
            }
            },
            setUserInfoToGo (userInfo) {
            this.$utils.setLoginState(userInfo)
            this.$router.push('/cms')
            },
            usernameChange (evt) {
            // evt ? this.username = evt && this.userPass ? this.isLoginBtnDisable = true && console.log(this.isLoginBtnDisable) : this.isLoginBtnDisable = false : this.username = null
            if (evt) {
                this.username = evt
                this.userPass ? this.isLoginBtnDisable = false : this.isLoginBtnDisable = true
            } else {
                this.username = null
                this.isLoginBtnDisable = true
            }
            },
            userPassChange (evt) {
            // evt ? this.userPass = evt && this.username ? this.isLoginBtnDisable = true : this.isLoginBtnDisable = false : this.userPass = null
            if (evt) {
                this.userPass = evt
                this.username ? this.isLoginBtnDisable = false : this.isLoginBtnDisable = true
            } else {
                this.userPass = null
                this.isLoginBtnDisable = true
            }
            },
            getSiteInfo () {
            let _self = this
            _self.$api.get('site', null, (er) => {}, (res) => {
                if (res.code === 0) {
                _self.siteinfo = res.data
                _self.$compUtils.setSiteInfo(res.data)
                }
            })
            }
        }
        }
        </script>
    
        <!-- Add "scoped" attribute to limit CSS to this component only -->
        <style scoped>
        .login{
            height: 100%;
            width: 100%;
        }
        .loginPage{
            height: 100%;
            width: 100%;
            background-image: linear-gradient(-180deg, #324157 38%, #00DEFF 100%);
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .loginForm{
            width: 30%;
        }
        .loginInput {
            margin: 10px 0;
        }
        .loginBtn {
            width: 100%;
        }
        </style>
  7. 效果
    login
    )

    ¶总结

    在登录组件中,我们封装了Axios,将其根据web请求(put、post、get和delete)形成统一的请求接口;在登录时向后台请求并完成登录信息在SessionStorage中存储及路由跳转。需要注意的是vue官方建议tab是2格,不然其Eslint会报错,编译不通过。

    // codes
    setUserInfoToGo (userInfo) {
      this.$utils.setLoginState(userInfo)
      this.$router.push('/cms')
    }
    // codes
目录
相关文章
|
19天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
105 1
|
29天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
55 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
51 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
45 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
38 1
vue学习第7章(循环)
|
2月前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
46 1
vue学习第九章(v-model)

相关实验场景

更多