十六、vue-lazyload的使用

  1. 首先,我们需要下载vue-lazyload包:

    npm i vue-lazyload -S
  2. 下载好之后,我们将它引入到自己的项目:

    //main.js
    //引入图片懒加载
    import VueLazyload from 'vue-lazyload'
    //vue-lazyload配置
    Vue.use(VueLazyload, {
    preLoad: 1.3,
    //发生错误时显示的图片
    error: require("./assets/error.gif"),
    //加载过程中用到的图片
    loading: require("./assets/loading.gif"),
    attempt: 1
    })
    1. 需要注意的一点是,由于webpack打包机制,和js编译原因,在动态引入图片时,要选择require方式,require 是 AMD规范引入方式,如果不用require引入,代码运行到此处时,只会将图片路径识别为普通字符串,而用require方式,则代码运行到此处时则会解析该字符串,并将解析值赋给该对象或者变量
  3. 然后在需要用到懒加载的img标签上,将:src替换为v-lazy,然后加上:key,其中v-lazy和:key的参数一样,然后就可以看到效果了

十七、对element-ui日历的修改以及实现签到功能

  1. 创建一个组件,calendar.vue,该组件为子组件,然后将其引入父组件forum.vue

  2. calendar.vue代码如下:

    <template>
    <div id="calendar">
    <div class="calendar-wrapper">
    <el-dialog title="签到" @closed="closeDialog" width="30%" :visible.sync="isDialog">
    <el-calendar v-model="checkInDate">
    <!-- 这里使用的是 2.5 slot 语法,对于新项目请使用 2.6 slot 语法-->
    <template class="selectCalendar" slot="dateCell" slot-scope="{date, data}">
    <p
    class="calendarContent"
    @click="checkIn(date,data)"
    :class="data.isSelected ? 'is-selected' : ''"
    >{{ data.day.split('-').slice(1).join('-') }} {{(data.isSelected) ? '✔️' : ''}}</p>
    </template>
    </el-calendar>
    </el-dialog>
    </div>
    </div>
    </template>
    <script>
    import { Message } from "element-ui";
    export default {
    name: "calendar",
    data: function() {
    return {
    isDialog: this.dialogCalendar,
    checkInDate: new Date(),
    activeDate: [
    "2019-08-19",
    "2019-08-20",
    "2019-08-21",
    "2019-08-22",
    "2019-08-23"
    ],
    selectDate: ""
    };
    },
    props: {
    dialogCalendar: {
    type: Boolean,
    default: false
    }
    },
    //监听从父组件传递给子组件的dialogCalendar的值,以便更新isDialog,解决props单向数据流报错的问题
    watch: {
    dialogCalendar: function(newVal) {
    this.isDialog = newVal;
    }
    },
    methods: {
    closeDialog: function() {
    //通过调用内建的$emit方法,传入事件名称和数据来改变父组件数据
    this.$emit("listenDialog", false);
    },
    checkIn: function(date, data) {
    let day1 = new Date();
    console.log(day1.getDate(), date.getDate(), data);
    if (date.getDate() == day1.getDate()) {
    Message.success({ message: "签到成功!", offset: 90 });
    } else {
    Message.warning({ message: "签到失败!", offset: 90 });
    }
    },
    }
    };
    </script>
    <style lang="scss">
    .is-selected {
    color: #1989fa;
    }
    #calendar {
    .el-calendar__body {
    padding: 12px 20px 10px;
    }
    .el-dialog__body {
    padding: 0px 20px;
    color: #606266;
    font-size: 14px;
    word-break: break-all;
    }
    .el-calendar-day {
    height: 50px;
    }
    }
    </style>
  3. forum.vue代码如下:

    ...
    <el-button type="success" plain @click="checkIn">每日签到</el-button>
    <calendar :dialogCalendar="post.dialogCalendar" @listenDialog="changeDialog"></calendar>
    ...
    post: {
    dialogCalendar: false,
    }
    ...
    methods: {
    //签到
    checkIn: function() {
    this.post.dialogCalendar = !this.post.dialogCalendar;
    console.log(this.post.dialogCalendar)
    },
    //通过接收子组件传值来改变父组件数据
    changeDialog: function(data) {
    this.post.dialogCalendar = data;
    console.log(data)
    }
    }
  4. 需要注意的一点是,因为父传子是单向数据流,那么当父子共用的值在子组件里发生变化时,会产生一个错误,所以在子组件值发生变化时,也要更新父组件值

从无到有构建vue实战项目(八)的更多相关文章

  1. 从无到有构建vue实战项目(四)

    六.webpack的安装和配置 为了快速构建vue项目,webpack是一个必不可少的工具,我们先来安装它,附上官网地址:https://www.webpackjs.com/ 要安装最新版本或特定版本 ...

  2. 从无到有构建vue实战项目(一)

    vue的安装 首先下载nodehttp://nodejs.cn/download/ 有两种安装方式安装包安装和二进制文件安装 输入以下命令,出现版本提示表示安装成功: node -v 10.15.3 ...

  3. 从无到有构建vue实战项目(二)

    二.vue项目的初步搭建 该项目我采用了当下最流行的vue ui框架---element-ui,首先用vue-cli构建一个vue项目: vue create education 然后会出现一系列配置 ...

  4. 从无到有构建vue实战项目(五)

    八.错误总结(一) webpack打包项目识别子组件路径问题 之所以出现了这样的问题是因为在webpack打包项目时,未将此处的子组件路径正确识别: 将此处的carousel改为carousel.vu ...

  5. 从无到有构建vue实战项目(三)

    四.响应式布局的实现 elemnt-ui参考bootatrap提供了响应式布局,附上地址:https://element.eleme.cn/#/zh-CN/component/layout 以下是我的 ...

  6. 从无到有构建vue实战项目(六)

    十.徒手撸一个vue下拉左侧二级导航 先附上最终效果图: vue代码: <div class="dropdown-menu-explore" v-on:mouseover=& ...

  7. 从无到有构建vue实战项目(七)

    十四.Vuex的使用 Vuex是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.Vu ...

  8. Vue 实战项目: 硅谷外卖(1)

    第 1 章: 准备 1.1. 项目描述 1) 此项目为外卖 WebApp(SPA) 2) 包括商家, 商品, 购物车, 用户等多个子模块 3) 使用 Vue 全家桶+ES6+Webpack 等前端最新 ...

  9. Vue 实战项目开发流程

    一 基础配备 ## 一.环境搭建 #### 1.安装node - 去[官网](https://nodejs.org/zh-cn/)下载node安装包 - 傻瓜式安装 - 万一安装后终端没有node环境 ...

随机推荐

  1. 【halcon教程资料】全网汇总如何快速、高效率学习机器视觉从入门到精通

    我以八年的视觉工程师开发的工作经验告诉你,你不要再因为学习halcon发愁了,我接触过很多学习halcon的小白,并不是不愿意学,而是不知道怎么快速.高效率的学习精通,一天天的过去了,对学习halco ...

  2. flink入门实战总结

    随着大数据技术在各行各业的广泛应用,要求能对海量数据进行实时处理的需求越来越多,同时数据处理的业务逻辑也越来越复杂,传统的批处理方式和早期的流式处理框架也越来越难以在延迟性.吞吐量.容错能力以及使用便 ...

  3. About dycf

    SYSU  数媒在读 所有资料可能与课程相关可能与参与项目相关 欢迎交流 . . . 中之人: ↓↓↓ ↑↑↑   是他  就是他  ↑↑↑

  4. windows下用easybcd引导ubuntu出现grub的解决方案

    linux安装时吧boot挂在到单独的分区 如果grub覆盖了mbr的话可以用pe工具箱修复windows的mbr linux引导项选grub 驱动器选安装时挂载了/boot的分区 添加条目 启动即可 ...

  5. Flutter学习笔记(13)--表单组件

    如需转载,请注明出处:Flutter学习笔记(13)--表单组件 表单组件是个包含表单元素的区域,表单元素允许用户输入内容,比如:文本区域,下拉表单,单选框.复选框等,常见的应用场景有:登陆.注册.输 ...

  6. JAVA-Spring AOP五大通知类型

    一.前置通知 在目标方法执行之前执行的通知 在前置通知方法,可以没有参数,也可以额外接收一个JoinPoint,Spring会自动将该对象传入,代表当前的连接点,通过该对象可以获取目标对象和目标方法相 ...

  7. Of efficiency and methodology

    There are only too many articles and books which pertains to the discussion of efficiency and method ...

  8. charles(version4.2.1)抓包手机数据

    点击菜单栏的Proxy项,选择Proxy Settings. 设置HTTP Proxy的Port. 勾选透明代理Enable transparent HTTP proxying,也可不勾选. 设置代理 ...

  9. Redis的分布式和主备配置调研

    目前Redis实现集群的方法主要是采用一致性哈稀分片(Shard),将不同的key分配到不同的redis server上,达到横向扩展的目的. 对于一致性哈稀分片的算法,Jedis-2.0.0已经提供 ...

  10. TensorFlow Data模块

    模块作用 tf.data api用于创建训练前导入数据和数据处理的pipeline,使得处理大规模数据,不同数据格式和复杂数据处理变的容易. 基本抽象 提供了两种基本抽象:Dataset和Iterat ...