vue项目实战

node连接服务器

【全栈初体验】Vue+Node+MySQL实现前后端分离开发_艾欢欢的博客-CSDN博客

node项目

 

1.猫眼电影移动端

在博客‘前端学习三’中项目入门的基础上进行

1.首先上图是测试了跳转,现在正式开发:要展示的是电影列表,这个列表对于正在上映和即将上映都需要,只是请求的数据/调用的接口不同,因此将其设置为一个组件

1.在components中新建一个moviesDetail.vue:其展示的内容是每次点击最上面的正在热映/即将上映触发一个请求进行返回的

2.index是页面,包含了最上面两个组件coming.vue和hoting.vue;

每一个组件中包含对应列表展示的组件

因此要把moviesDetail.vue引入到coming.vue和hoting.vue中:

注意导入与引入的组件名称要一致,注册组件的名称与在使用的时候的标签要一致

在moviesDetail.vue中导出组件
<script>
export default {
  name: "movieList",
 // props: ["mitem"], //通过mitem属性接收父组件的传值
  data() {
    return {};
  }
};
</script>


在coming.vue和hoting.vue中引入组件注册组件

<script>
 
import movieList from '@/components/moviesDetail' //引入组件

export default {
  name: 'coming',
  components: {
    movieList  //注册组件
  }
 }   // ... 其他代码,可参考本节的demo
</script>

export default {
  name: "hoting",
  data() {
    return {
      hotList: []
    };
  },
  created() {
    axios
      .get("http://www.softeem.xin/maoyanApi/ajax/movieOnInfoList")
      .then(res => {
        this.hotList = res.data.movieList;
      });
  },
  components: {
    movieList //注册组件
  }
};
</script>


这样使用的时候就可以使用下面的标签
 <!-- 使用组件 -->
      <movieList></movieList>

2.然后每一个按钮也会触发一个对应的请求,完成页面之间的跳转

1.跳转:比如点击一个按钮要跳转到其详情页面,并且需要传递参数:为该按钮定义点击事件,当发生单击事件的时候拍触发tomovieDetail 事件,并且将参数传入到对应的详情页。

tomovieDetail 是一个页面,通过路由跳转到当前页面:这样写好这个页面后那就可以进行跳转了

路由:就是在router下的js文件中进行配置,配置路径对应的组件(路径就是当前的请求,组件就是要跳转的页面)

该页面也可以拆分成一个组件,因为不同的电影进入详情页的标题是不同步的,而且多个电影都需要有详情,所以把他作为一个组件比较好

2.获取后台数据展示:这里会通过id触发一个请求,调用接口异步获取数据

<!-- moviesDetail.vue 路径:src/components -->
<template>
  <div>
    <div @click="$router.push({name:'tomovieDetail',query:{id:mitem.id}})" class="movie-list">
      </div>
      // ...其它代码
    </div>
</template>
 

3.加载动画组件

是的进去页面的时候是动画加载的,比如我们进去一个页面,他的标题是拥有动画效果的

eg:比如这样,可以写一个动画的组件,加载一个动图
可以处理上面问题:当所需要请求的异步数据没有完全加载时,就可以加载一个动态的加载符号 /加载中,请稍后等等都是类似的组件思想     
   可以在进入页面的时候有一个判断:如果数据已经得到就直接展示;如果数据没有获取到或者没有完全获取到就展示动图  这样当数据架子啊完成的时候动图就“消失”了

定义动画组件

<template>
  <div>
    <div class="loading-bg">
      <img class="loading" src="../assets/img/loading.gif">
    </div>
  </div>
</template>
<script>
export default {
  name: "loading"
};
</script>
<style lang='scss' scoped>
// ...样式参考demo
</style>

使用动画组件:同样需要导出组件 引入注册组件-------写在script里面

然后 在templte中进行写入

eg
 <!-- isReady: 数据加载好了就不显示loading动画 -->
     <loading v-if="!isReady"></loading>

4.图片懒加载

不使用图片懒加载的情况下,会在页面第一次加载时,将所有图片资源进行加载。假设有大量图片资源需要加载,则等待加载完成会需要很长时间,极其影响用户体验。这个时候使用图片懒加载就很有必要性,它会只加载你当前屏幕中的图片资源。

需要安装 vue-lazyload

首先在main.js 文件中引入并使用

// 图片懒加载
import VueLazyload from 'vue-lazyload'
import errorImg from '../src/assets/img/error.png'
import loadingImg from '../src/assets/img/loading.gif'

// 加载懒加载插件
Vue.use(VueLazyload,{
  error: errorImg,
  loading: loadingImg
})
 
然后在需要使用图片懒加载的地方,将 :src 修改为 v-lazy 即可

3.APP端的底部导航栏

应该就是几个按钮,点击不同的按钮会进入不同的组件;因此之前写好的那就是导航栏中的一个

2.猫眼电影web端

代码已经下载 gouyan-movie-vue-master

3.猫眼电影小程序

代码已经下载

4.一个商品订单管理:GitHub - macrozheng/mall-admin-web: mall-admin-web是一个电商后台管理系统的前端项目,基于Vue+Element实现。 主要包括商品管理、订单管理、会员管理、促销管理、运营管理、内容管理、统计报表、财务管理、权限管理、设置等功能。

代码:mall-admin-web-master

在线演示:mall-admin-web

5.在github上面查找

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值