用Vue实现个人博客的前端界面1

<!--原网页: http://www.jianshu.com/p/aa46fbf198e2?open_source=weibo_search -->
学习如何使用vue-cli,去组件化的开发一个项目;以及如何使用路由vue-router,完成页面之间的跳转;还有vuex如何管理页面之间需要交互的全局数据;如何使用vue-resource跨域请求,node后台又如何配置。

一. 使用的技术栈
后台:nodejs + express + mongodb + mongoose
前端:vue + vue-router + vuex + vue-router
后台是自己之前就写过的一个基于nodejs的个人博客的练习,当时是转发页面的形式,即将页面和数据一同传给浏览器,现在只是改成接口的形式,只发送数据,感兴趣的同学可以去github下载:https://github.com/SpiritLiftedHigh/BlogAPI

二. 项目预览
    略

三. 一些问题的解决
1 . 页面静态资源的配置:
(1)将图片资源放在static文件夹中
一开始,觉得静态资源都应该发在assets文件夹的,可是因为图片的名字是存在服务器端的,在渲染页面时,图 片的路径需要使用字符串拼接,发现如果将路径写成静态的就会直接映射到static目录下,可是如果是动态拼接的话,就不能成功映射。
(2)bootstrap的部署
        因为bootstrap是完全依赖jQuery的,所以要使用bootstrap,就必须先下载并配置jQuery。如下:
打开build/webpack.base.conf.js,添加如下配置:
plugins: [
   new webpack.optimize.CommonsChunkPlugin('common.js'),
   new webpack.ProvidePlugin({
     jQuery: "jquery",
     $: "jquery"
   })
  ],
将resolve改为入下的配置:
resolve: {
   extensions: ['.js', '.vue', '.json'],
   alias: {
   'vue$': 'vue/dist/vue.esm.js',
   '@': resolve('src'),
   'bootstrap':resolve('src/assets/bootstrap'),
   }
}
在main.js中直接导入:
import './assets/bootstrap/css/bootstrap.min.css' 
import './assets/bootstrap/js/bootstrap.min.js'
2 . vuex的使用
首先下载,然后进入main.js文件,并添加如下代码:
import Vuex from 'vuex'
Vue.use(Vuex)
const  vuex_store = new Vuex.Store({
    state:{
        totalmess: 0,  //未读消息总数,在footer公用组件
        title: '登录' //每个页面的名称,在nav公用组件中
    },
    mutations:{
        
    }
})
new Vue({
  el: '#app',
  router,
  template: '<App/>',
  components: { App },
  store: vuex_store  //注入vue实例中,这样所有组件都可以获取
})
在nav组件中的使用:
<div class="header"><span>{{this.$store.state.title}}</span></div>
在其他组件中的使用,比如消息显示页面:
this.$store.state.title = '消息';
这样每个组件中的变化,都可以体现在nav公用组件中。
3 . 路由之间的跳转和参数的传递,以及获取
(1)路由的跳转(在代码中动态跳转):
this.$router.push({path: '/list'});
(2)通过链接跳转时的传参和获取参数
路由的配置:
export default new Router({
  routes: [
    {
      path: '/blog/:id',
      name: 'blog',
      component: blog
    }
]
})
跳转传参:
<router-link :to="{path: '/blog/' + blog._id}"></router-link>
获取参数:
let blogid = this.$route.params.id;
4 . vue-resource跨域请求,保存session
在后台配置好的情况下,必须要发送cookie,不然后台不能保存session,所以在每次请求时都必须发送cookie
this.$http.get(url, { 
    withCredentials: true  //打开cookie
}).then( res => {
    //
}).catch( error => {
    //
})
后台接口API:https://github.com/SpiritLiftedHigh/BlogAPI
前端vue实现:https://github.com/SpiritLiftedHigh/xiaojingBlog



  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Vue实现前端登录界面和API接口,您需要遵循以下步骤: 1. 安装Vue 您可以通过npm来安装Vue。在终端中运行以下命令: ``` npm install vue ``` 2. 创建Vue应用 您可以使用Vue CLI来创建一个新的Vue应用程序。在终端中运行以下命令: ``` vue create my-app ``` 3. 创建登录组件 在您的Vue应用程序中,您可以创建一个名为Login.vue的组件来处理用户登录逻辑。这个组件应该包括一个表单,允许用户输入他们的用户名和密码。当用户提交表单时,您可以使用axios库向后端API发送POST请求以进行身份验证。 以下是一个简单的例子: ```vue <template> <form @submit.prevent="login"> <label> 用户名: <input type="text" v-model="username" required> </label> <label> 密码: <input type="password" v-model="password" required> </label> <button type="submit">登录</button> </form> </template> <script> import axios from 'axios'; export default { data() { return { username: '', password: '' } }, methods: { login() { axios.post('/api/login', { username: this.username, password: this.password }).then(response => { // 处理登录成功逻辑 }).catch(error => { // 处理登录失败逻辑 }); } } } </script> ``` 在这个例子中,我们使用了axios库来发送POST请求到后端API中的/login路由。在请求中,我们包含了用户输入的用户名和密码。如果请求成功,我们将会处理登录成功的逻辑。如果请求失败,我们将会处理登录失败的逻辑。 4. 创建API接口 您可以使用Node.js和Express来创建一个简单的API接口,用于处理用户登录逻辑。您可以创建一个名为server.js的文件,其中包含以下代码: ```javascript const express = require('express'); const bodyParser = require('body-parser'); const app = express(); app.use(bodyParser.json()); app.post('/api/login', (req, res) => { const username = req.body.username; const password = req.body.password; // 在这里处理身份验证逻辑 if (username === 'admin' && password === 'admin') { res.send({ success: true }); } else { res.status(401).send({ success: false, message: '用户名或密码错误' }); } }); app.listen(3000, () => { console.log('API接口已启动'); }); ``` 在这个例子中,我们使用了Express框架来创建一个简单的API接口。我们在路由/api/login中处理用户登录逻辑。我们从请求中获取用户名和密码,然后进行身份验证。如果身份验证成功,我们将返回一个包含success属性的JSON对象。如果身份验证失败,我们将返回一个HTTP 401未授权状态码和一个包含错误消息的JSON对象。 5. 运行应用程序 现

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值