文章目录
首页模块
01-首页-路由与组件
目的: 搭建页面架子,便于接下来进行页面布局组件编写。
- 根组件下定义一级路由组件出口
src/App.vue
<template>
<!-- 一级路由 -->
<router-view></router-view>
</template>
- 一级路由布局容器
src/views/Layout.vue
<template>
<nav>顶部通栏</nav>
<header>头部</header>
<main>
<!-- 二级路由 -->
<router-view></router-view>
</main>
<footer>底部</footer>
</template>
<script>
export default {
name: 'xtx-layout'
}
</script>
<style scoped lang='less'></style>
- 二级路由首页组件
src/views/home/index.vue
<template>
<div class='xtx-home-page'>
首页
</div>
</template>
<script>
export default {
name: 'xtx-home-page'
}
</script>
<style scoped lang='less'></style>
- 配置路由规则
src/router/index.js
import { createRouter, createWebHashHistory } from 'vue-router'
+const Layout = () => import('@/views/Layout')
+const Home = () => import('@/views/home/index')
const routes = [
+ {
+ path: '/',
+ component: Layout,
+ children: [
+ { path: '/', component: Home }
+ ]
+ }
]
const router = createRouter({
history: createWebHashHistory(),
routes
})
export default router
总结: 配置首页的路由规则,由Layout和首页组件组成。
02-首页-less的自动化导入
目的: 准备常用less变量,混入代码,完成自动导入。
1)准备要用的变量和混入代码
- 变量
src/assets/styles/variables.less
// 主题
@xtxColor:#27BA9B;
// 辅助
@helpColor:#E26237;
// 成功
@sucColor:#1DC779;
// 警告
@warnColor:#FFB302;
// 价格
@priceColor:#CF4444;
- 混入
src/assets/styles/mixins.less
// 鼠标经过上移阴影动画
.hoverShadow () {
transition: all .5s;
&:hover {
transform: translate3d(0,-3px,0);
box-shadow: 0 3px 8px rgba(0,0,0,0.2);
}
}
less混入就是,申明一段css代码(选择器包裹的代码)或者函数,在其他css选择器调用,可复用包裹的代码。
2)完成自动注入公用变量和混入
遇到问题: 每次使用公用的变量和mixin的时候需要单独引入到文件中。
解决方法: 使用vuecli的style-resoures-loader插件来完成自动注入到每个less文件或者vue组件中style标签中。
-
在当前项目下执行一下命令
vue add style-resources-loader
,添加一个vuecli的插件
-
安装完毕后会在
vue.config.js
中自动添加配置,如下:
module.exports = {
pluginOptions: {
'style-resources-loader': {
preProcessor: 'less',
patterns: []
}
}
}
- 把你需要注入的文件配置一下后,重启服务即可。
+const path = require('path')
module.exports = {
pluginOptions: {
'style-resources-loader': {
preProcessor: 'less',
patterns: [
+ path.join(__dirname, './src/assets/styles/variables.less'),
+ path.join(__dirname, './src/assets/styles/mixins.less')
]
}
}
}
总结: 知道如何定义less变量和混入代码并使用他们,通过vue-resources-loader完成代码注入再每个less文件和vue组件中。
03-首页-样式重置与公用
目的: 准备网站所需的重置样式代码,以及一些公用样式代码。
- 重置样式
执行npm i normalize.css
安装重置样式的包,然后在main.js
导入normalize.css
即可。
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
+import 'normalize.css'
createApp(App).use(store).use(router).mount('#app')
- 公用样式
新建文件src/assets/styles/common.less
在该文件写入常用的样式,然后在main.js
导入即可。
src/assets/styles/common.less
// 重置样式
* {
box-sizing: border-box;
}
html {
height: 100%;
font-size: 14px;
}
body {
height: 100%;
color: #333;
min-width: 1240px;
font: 1em/1.4 'Microsoft Yahei', 'PingFang SC', 'Avenir', 'Segoe UI', 'Hiragino Sans GB', 'STHeiti', 'Microsoft Sans Serif', 'WenQuanYi Micro Hei', sans-serif
}
ul,
h1,
h3,
h4,
p,
dl,
dd {
padding: 0;
margin: 0;
}
a {
text-decoration: none;
color: #333;
outline: none;
}
i {
font-style: normal;
}
input[type="text"],
input[type="search"],
input[type="password"],
input[type="checkbox"]{
padding: 0;
outline: none;
border: none;
-webkit-appearance: none;
&::placeholder{
color: #ccc;
}
}
img {
max-width: 100%;
max-height: 100%;
vertical-align: middle;
}
ul {
list-style: none;
}
#app {
background: #f5f5f5;
user-select: none;
}
.container {
width: 1240px;
margin: 0 auto;
position: relative;
}
.ellipsis {
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
}
.ellipsis-2 {
word-break: break-all;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
overflow: hidden;
}
.fl {
float: left;
}
.fr {
float: right;
}
.clearfix:after {
content: ".";
display: block;
visibility: hidden;
height: 0;
line-height: 0;
clear: both;
}
src/main.js
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import 'normalize.css'
+import '@/assets/styles/common.less'
createApp(App).use(store).use(router).mount('#app')
总结: 重置样式使用normalize.css,项目公用样式common.less
04-首页-顶部通栏布局
目的: 完成顶部通栏组件。
大致步骤:
1)在 public/index.html 引入字体图标文件。
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
+ <link rel="stylesheet" href="//at.alicdn.com/t/font_2143783_iq6z4ey5vu.css">
<title><%= htmlWebpackPlugin.options.title %></title>
2)在 src/components/ 下新建 app-topnav.vue 组件,基础布局如下:
<template>
<nav class="app-topnav">
<div class="container">
<ul>
<li><a href="javascript:;"><i class="iconfont icon-user"></i>周杰伦</a></li>
<li><a href="javascript:;">退出登录</a></li>
<li><a href="javascript:;">请先登录</a></li>
<li><a href="javascript:;">免费注册</a></li>
<li><a href="javascript:;">我的订单</a></li>
<li><a href="javascript:;">会员中心</a></li>
<li><a href="javascript:;">帮助中心</a></li>
<li><a href="javascript:;">关于我们</a></li>
<li><a href="javascript:;"><i class="iconfont icon-phone"></i>手机版</a></li>
</ul>
</div>
</nav>
</template>
<script>
export default {
name: 'AppTopnav'
}
</script>
<style scoped lang="less">
.app-topnav {
background: #333;
ul {
display: flex;
height: 53px;
justify-content: flex-end;
align-items: center;
li {
a {
padding: 0 15px;
color: #cdcdcd;
line-height: 1;
display: inline-block;
i {
font-size: 14px;
margin-right: 2px;
}
&:hover {
color: @xtxColor;
}
}
~ li {
a {
border-left: 2px solid #666;
}
}
}
}
}
</style>
3)在 src/views/Layout.vue 中导入使用。
<template>
+ <AppTopnav/>
<header>头部</header>
<main>
<!-- 二级路由 -->
<router-view></router-view>
</main>
<footer>底部</footer>
</template>
<script>
+import AppTopnav from '@/components/app-topnav'
export default {
name: 'XtxLayout',
+ components: { AppTopnav }
}
</script>
<style scoped lang='less'></style>
4)根据当前的登录状态显示 用户名和退出登录
<script>
import { useStore } from 'vuex'
import { computed } from 'vue'
export default {
name: 'AppTopnav',
setup () {
const store = useStore()
const profile = computed(()=>{
return store.state.user.profile
})
return { profile }
}
}
</script>
<template v-if="profile.token">
<li><a href="javascript:;"><i class="iconfont icon-user"></i>{{profile.account}}</a></li>
<li><a href="javascript:;">退出登录</a></li>
</template>
<template v-else>
<li><a href="javascript:;">请先登录</a></li>
<li><a href="javascript:;">免费注册</a></li>
</template>
总结: 完成基础布局,根据用户信息动态展示导航菜单。
05-首页-头部布局
目的: 完成首页头部布局,了解结构。
大致步骤:
- 1)在 src/components/ 下新建 app-header.vue 组件,基础布局如下:
<template>
<header class='app-header'>
<div class="container">
<h1 class="logo"><RouterLink to="/">小兔鲜</RouterLink></h1>
<ul class="navs">
<li class="home"><RouterLink to="/">首页</RouterLink></li>
<li><a href="#">美食</a></li>
<li><a href="#">餐厨</a></li>
<li><a href="#">艺术</a></li>
<li><a href="#">电器</a></li>
<li><a href="#">居家</a></li>
<li><a href="#">洗护</a></li>
<li><a href="#">孕婴</a></li>
<li><a href="#">服装</a></li>
<li><a href="#">杂货</a></li>
</ul>
<div class="search">
<i class="iconfont icon-search"></i>
<input type="text" placeholder="搜一搜">
</div>
<div class="cart">
<a class="curr" href="#">
<i class="iconfont icon-cart"></i><em>2</em>
</a>
</div>
</div>
</header>
</template>
<script>
export default {
name: 'AppHeader'
}
</script>
<style scoped lang='less'>
.app-header {
background: #fff;
.container {
display: flex;
align-items: center;
}
.logo {
width: 200px;
a {
display: block;
height: 132px;
width: 100%;
text-indent: -9999px;
background: url(../assets/images/logo.png) no-repeat center 18px / contain;
}
}
.navs {
width: 820px;
display: flex;
justify-content: space-around;
padding-left: 40px;
li {
margin-right: 40px;
width: 38px;
text-align: center;
a {
font-size: 16px;
line-height: 32px;
height: 32px;
display: inline-block;
}
&:hover {
a {
color: @xtxColor;
border-bottom: 1px solid @xtxColor;
}
}
}
}
.search {
width: 170px;
height: 32px;
position: relative;
border-bottom: 1px solid #e7e7e7;
line-height: 32px;
.icon-search {
font-size: 18px;
margin-left: 5px;
}
input {
width: 140px;
padding-left: 5px;
color: #666;
}
}
.cart {
width: 50px;
.curr {
height: 32px;
line-height: 32px;
text-align: center;
position: relative;
display: block;
.icon-cart{
font-size: 22px;
}
em {
font-style: normal;
position: absolute;
right: 0;
top: 0;
padding: 1px 6px;
line-height: 1;
background: @helpColor;
color: #fff;
font-size: 12px;
border-radius: 10px;
font-family: Arial;
}
}
}
}
</style>
- 2)在 src/views/Layout.vue 中导入使用。
<template>
<AppTopnav/>
+ <AppHeader/>
<main>
<!-- 二级路由 -->
<router-view></router-view>
</main>
<footer>底部</footer>
</template>
<script>
import AppTopnav from '@/components/app-topnav'
+import AppHeader from '@/components/app-header'
export default {
name: 'XtxLayout',
+ components: { AppTopnav, AppHeader }
}
</script>
<style scoped lang='less'></style>
总结: 准备了一个静态的头部组件,了解其结构。