vue - blog开发学习2
首页博客列表的开发
1、修改index.vue,使能够支持列表功能
<template>
<div>
<PostList v-for="(item,index) in postList" :title="item.title" :content="item.content" :postCount="postCount"
:key="index"></PostList>
</div>
</template> <script>
import PostList from '@/components/post-list' export default {
name: "index",
components: {
PostList
},
data() {
return {
postList: [
{
title: '测试1',
content: '啊啊啊啊啊啊啊啊啊啊啊'
},
{
title: '测试1',
content: '啊啊啊啊啊啊啊啊啊啊啊'
},
{
title: '测试1',
content: '啊啊啊啊啊啊啊啊啊啊啊'
},
{
title: '测试1',
content: '啊啊啊啊啊啊啊啊啊啊啊'
},
],
postCount: 100
}
} }
</script> <style scoped> </style>
2、添加PostList自定义组件,自定义组件中使用到了iView中的Card标签
<template>
<div style="background: #eee;padding: 1px;">
<Card :bordered="false">
<p>{{title}}</p>
<p>{{content}}</p>
</Card>
</div>
</template> <script>
export default {
name: "PostList",
props: {
title: {
type: String,
default: ''
},
content: {
type: String,
default: ''
},
postCount: {
type: Number,
default: 0
}
}
}
</script> <style scoped> </style>
3、效果(访问根路径的话,会自动渲染index.vue中的内容,具体看router/index.js中的路由配置)

4、用router-link生成一个可点击的链接,使能够跳转到具体内容页面(post.vue)--页面还是渲染到home.vue中,修改post-list.vue组件,添加了一个router-link,这样,再点击每一块的时候都会跳转到post.vue中,并且会带着postId值
<template>
<div style="background: #eee;padding: 1px; margin-left: 10%;margin-right: 10%">
<router-link tag="div" :to="{name:'Post',params:{postId:postId}}">
<Card :bordered="false">
<p>{{title}}</p>
<p>{{content}}</p>
</Card>
</router-link>
</div>
</template> <script>
export default {
name: "PostList",
props: {
postId: {
type: String,
default: ''
},
title: {
type: String,
default: ''
},
content: {
type: String,
default: ''
},
postCount: {
type: Number,
default: 0
}
},
methods: {}
}
</script> <style scoped> </style>

5、修改home页的menu标签,改成根据数据自动渲染菜单,zIndex这个是为了不覆盖菜单
<template>
<div class="layout">
<Layout>
<Header :style="{position: 'fixed', width: '100%',zIndex:'900'}">
<Menu mode="horizontal" theme="dark" active-name="1">
<div class="layout-logo">
<img src="static/img/logo.png" alt="">
</div>
<div class="layout-nav">
<MenuItem v-for="(item,index) in menuList" :name="index" :to="item.to" :key="index">
<Icon :type="item.icon"></Icon>
{{item.name}}
</MenuItem>
</div>
</Menu>
</Header> <Content :style="{margin: '88px 0 0', background: '#fff', minHeight: '500px'}">
<router-view></router-view>
</Content>
<Footer class="layout-footer-center">2011-2016 © TalkingData</Footer>
</Layout>
</div>
</template> <script>
export default {
name: "home",
data() {
return {
menuList:[
{
name:'首页',
icon:'ios-navigate',
to:'index'
},
{
name:'类别',
icon:'ios-keypad',
to:'postClass'
},
{
name:'新建',
icon:'ios-analytics',
to:'create'
},
{
name:'修改',
icon:'ios-paper',
to:'edit'
},
{
name:'关于我',
icon:'ios-paper',
to:'aboutMe'
}
]
}
}
}
</script> <style scoped>
@import "../static/css/home.css"; </style>
6、首页基本功能写完后,使用mock模拟后台返回的json数据,此方式基于axios发送请求方式,因此安装axios
①npm install axios --save
②安装完成之后,将axios绑定为全局函数,因此在main.js中添加
import axios from 'axios'
Vue.prototype.$axios = axios
使用时:
this.$axios.get('api/getNewsList')
.then((response)=>{
this.newsList=response.data.data;
}).catch((response)=>{
console.log(response);
})
或者
import axios from 'axios'
import VueAxios from 'vue-axios'
Vue.use(VueAxios,axios);
使用:
this.axios.get('api/getNewsList').then((response)=>{
this.newsList=response.data.data;
}).catch((response)=>{
console.log(response);
})
③安装mockjs
npm install mockjs --save-dev //开发使用 所以加上dev
④修改main.js,添加自定义的mock.js(http://mockjs.com/)
https://blog.csdn.net/xiaoxiaojie12321/article/details/81301399
require('./mock/mock.js')
⑤自定义mock.js
//引入mockjs
const Mock = require('mockjs')
// 获取mock.Random对象
const Random = Mock.Random
//mock数据
const data = () => {
let posts = []
for (let i = 0; i < 50; i++) {
let post = {
title: Random.csentence(5, 30),
content: Random.csentence(4000, 5000)
}
posts.push(post)
} return {
posts: posts
}
} Mock.mock('/api/posts','get',data)
⑥修改index.vue中的获取数据的方式
created() {
this.$axios({
url: '/api/posts',
method: 'get'
}).then(response => {
this.postList = response.data.posts
console.log(this.postList)
})
}
⑦添加bootstrap支持
npm install bootstrap jquery --save
webpack.base.conf.js
plugins:[
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
"windows.jQuery": "jquery"
})
],
main.js
//boostrap
import $ from 'jquery'
import 'bootstrap/dist/css/bootstrap.min.css'
import 'bootstrap/dist/js/bootstrap.min.js'
整体:

点击每一个框:

vue - blog开发学习2的更多相关文章
- vue - blog开发学习5
基本功能和后台联调 1.首页的所有博客 因为是前后台都是本地开发,所以前端vue需要设置proxy:修改/config/index.js中的这个proxyTable proxyTable: { '/a ...
- vue - blog开发学习1
1.安装vue-cli vue intall -g vue-cli 2.创建项目 vue init webpack nblog 3.按提示要求配置项目 ? Project name nblog ? P ...
- vue - blog开发学习6
1.问题,如下图,使用iviewui中的card导致页面不能出现滚动条(不太会弄,在网上查了一个vue组件vuescroll,因此使用这个做滚动条) 2.安装vuescroll cnpm instal ...
- vue - blog开发学习4
1.新建页面的修改,集成富文本编辑 edit-post.vue(新建和修改都用该组件) <template> <div class="editor"> &l ...
- vue - blog开发学习3
1.添加less 和less-loader支持 npm install less less-loader --save-dev 2.新建main.less,将这个样式添加到home.vue中的cont ...
- vue - blog开发学7
将基本的项目部署到linux上(前后台只是实现了基本的功能,本次只是记录一些基本的开发流程,完善,等后续) 1.linux环境准备(我用的是阿里云服务器) ①jre.mysql,Nginx基本上这些就 ...
- Vue学习笔记-Vue.js-2.X 学习(二)===>组件化开发
===重点重点开始 ========================== (三) 组件化开发 1.创建组件构造器: Vue.extends() 2.注册组件: Vue.component() 3.使用 ...
- 前端开发 Vue -1windows环境搭建Vue Node开发环境
解决几个疑问: 想学习下vue.js,我理解的它是一个前端的框架,主要作用是对数据的处理,和juqery类似,所以不太理解为什么要在nodejs中npm install vue呢?在html文件中引入 ...
- Android开发学习路线图
Android开发学习方法: Android是一个比较庞大的体系,从底层的Linux内核到上层的应用层,各部分的内容跨度也比较大.因此,一个好的学习方法对我们学习Android开发很重要. 在此建议, ...
随机推荐
- 字典dict详解
字典也是 Python 提供的一种常用的数据结构,它用于存放具有映射关系的数据. 比如有份成绩表数据,语文:79,数学:80,英语:92,这组数据看上去像两个列表,但这两个列表的元素之间有一定的关联关 ...
- Codefores 507C Guess Your Way Out!(递归)
C. Guess Your Way Out! time limit per test 1 second memory limit per test 256 megabytes input standa ...
- 容器下载的是centos8的镜像,scp出现packet_write_wait: Connection to **** port 22: Broken pipe 问题解决
解决方案:在~/.ssh目录新建文件config vi ~/.ssh/config #Added lines to fix. Host * IPQoS lowdelay t ...
- Java开发中的23种设计模式详解(3)行为型
本章是关于设计模式的最后一讲,会讲到第三种设计模式--行为型模式,共11种:策略模式.模板方法模式.观察者模式.迭代子模式.责任链模式.命令模式.备忘录模式.状态模式.访问者模式.中介者模式.解释器模 ...
- spring整合mybatis后,mybatis一级缓存失效的原因
一般来说,可以在5个方面进行缓存的设计: 最底层可以配置的是数据库自带的query cache, mybatis的一级缓存,默认情况下都处于开启状态,只能使用自带的PerpetualCache,无法配 ...
- 在脚本中使用set命令调试脚本
当脚本文件较长时,可以使用set命令指定调试一段脚本.在脚本中使用set -x命令开启调式模式:使用set +x命令关闭调式模式. 例如: #!/bin/bash #Scriptname: greet ...
- EBCDIC 1025 俄语
https://en.wikipedia.org/wiki/EBCDIC_1025 EBCDIC 1025 _0 _1 _2 _3 _4 _5 _6 _7 _8 _9 _A _B _C _D _E ...
- 【串线篇】浅谈BeanFactory
BeanFactory&ApplicationContext BeanFactory: bean工厂接口,负责创建bean实例, 容器里保存的所有单例bean其实是一个map<key-- ...
- 2018/8/26学习Mysql笔记
SELECT * FROM product; #.基本增删改查 #新增 #需求:添加一条数据到产品表 产品名称为苹果手机 卖价为5000 ); #删除 #需求:删除产品表中id=20的数据 ; #需求 ...
- 怀旧浪潮来袭,小霸王游戏、windows95......曾经的经典哪些能戳中你的心怀?
随着前两天上架的 Rewound 在 iPhone 上复刻了 iPod Classic为大家掀起一场怀旧浪潮,那么除了 Rewound还有什么经典?今天我们就来怀旧一下那些曾经的经典.80经典小霸王游 ...