2.3【微信小程序全栈课程】index页面完善--vue文件代码解析

简介: 这一节我们继续完善index页面,编辑src/pages/index/index.vue文件,在实际项目开发中,让大家继续了解vue

1、template 部分

(1)修改template部分的代码


template里面包含html代码,对应着原生小程序框架里中的.wxml文件。我们将index.vue文件中的template部分的代码修改成下面的代码


<template>
  <div>
    <div class="show">
      <div class="mark-text">当前分数</div>
      <div class="mark">{{mark}}</div>
    </div>
    <div class="row">
      <div class="right button" @click='addMark(1)'>+ 1</div>
      <div class="left button" @click='addMark(-1)'>- 1</div>
    </div>
    <div class="row">
      <div class="right button" @click='addMark(5)'>+ 5</div>
      <div class="left button" @click='addMark(-5)'>- 5</div>
    </div>
  </div>
</template>
(2)在标签下只能有一个子节点元素


html的所有代码必须包含在一个 html 标签中,如果写多个如

这样的标签则会报错,如下所示:


正确示例


<template>
<div>
  <div>
    //html页面代码
  </div>
</div>
</template>


错误示例


<template>
<div>
  //html页面代码
</div>
<div>
  //html页面代码
</div>
</template>


(3)双大括号{{ }}


<div class="mark">{{mark}}</div>


双大括号{{ }}会将数据解释为普通文本,而非 HTML 代码。里面一般包裹的是vue.js的变量或者方法,这些变量、方法要先在script里面定义


(4)点击事件@click


<div class="right button" @click='addMark(1)'>+ 1</div>


@click是v-on:click的缩写,是给html标签添加的点击事件,addMark(1)是在script里面的method对象中定义的方法


2、script 部分


(1)修改script部分的代码


script里面包含js代码,对应着原生小程序框架里中的.js文件。我们将index.vue文件中的script部分的代码修改成下面的代码


<script>
  export default {
    data () {
      return {
        mark: 0
      }
    },
    methods: {
      addMark (add) {
        //this.mark = 0 + 1
        this.mark = this.mark + add
        console.log("mark",this.mark)  
      }
    }
  }
</script>


(2)data对象


data里面定义的是数据,我们在这里定义了mark并赋值为0。在 template中,通过{{mark}}来使用数据。在script的methods对象中,通过this.mark来使用数据


data () {
  return {
    mark: 0
  }
}


data 选项必须是一个函数,不然vue实例之间可能会相互影响。比如,像下面这样定义就是错误的~


data: { 
  mark: 0
}


(3)methods对象


methods对象里面定义的是vue的方法,也可以说是函数。比如,下面代码就表示,我们自定义了一个叫 addMark 的方法函数。


add是addMark方法的参数,在template中通过@click调用的addMark(1)就是将add参数作为1,此时mark = 0 + 1 变成了1,console.log语句是可以将结果打印到微信开发者工具中的控制台,我们一般用来测试。


methods: {
  addMark (add) {
    //this.mark = 0 + 1
    this.mark = this.mark + add
    console.log("mark为:",this.mark)  
  }
}


3、style 部分


script部分比较简单,里面包含css代码,对应着原生小程序框架里中的.wxss文件。就是将template里出现的html元素加一些样式。我们将index.vue文件中的script部分的代码修改成下面的代码。


样式部分与我们的代码逻辑关系不大,我们不做详细讲解了,写代码的时候,直接粘贴就可以了。


<style lang='scss'>
.show{
  text-align:center;
  height:266px;
  background: #EA5149;
  margin-bottom:5px;
  color: #FFFFFF;
  font-weight:bold;
  .mark-text{
    font-size: 20px;
    padding:28px;
  }
  .mark{
    font-size: 88px;
  }
  .button{
    margin:0 10px;
    height: 30px;
    line-height:30px;
    text-align:center;
    font-size: 15px;
    font-weight:bold;
    background:#EA5149;
    .btn0{
      width: 60px;
      border-radius: 15px;
      border:1px dashed #feb600;
    }
    .btn1{
      width: 60px;
      border-radius: 15px;
      border:1px dashed #feb600;
    }
  }
}
.row{
  margin: 40px 56px;
  .button{
    width: 70px;
    height: 70px;
    line-height:70px;
    border-radius: 20%;
    border: none;
    text-align:center;
    font-size: 25px;
    color:#FFFFFF;
    font-weight:bold;
  }
}
.right{
  background:#EA5149;
  float: right;
}
.left{
  background:#feb600;
  margin-right:80px;
}
</style>


Vue官方文档


https://cn.vuejs.org/v2/guide/


如果以前没有接触过vue,可能看到vue代码会有点懵,建议花点时间看一下vue 的官方文档,对vue有一个大概的认识,不然下面的学习可能会比较困难。


4、测试效果


先在项目目录中运行npm run dev


~/WeChatProjects/truth_hold$ npm run dev

在微信开发者工具中点击加减按钮,会看到以下效果


image.png


5、index.vue代码示例


<template>
  <div>
    <div class="show">
      <div class="mark-text">当前分数</div>
      <div class="mark">{{mark}}</div>
    </div>
    <div class="row">
      <div class="right button" @click='addMark(1)'>+ 1</div>
      <div class="left button" @click='addMark(-1)'>- 1</div>
    </div>
    <div class="row">
      <div class="right button" @click='addMark(5)'>+ 5</div>
      <div class="left button" @click='addMark(-5)'>- 5</div>
    </div>
  </div>
</template>
<script>
  export default {
    data () {
      return {
        mark: 0
      }
    },
    methods: {
      addMark (add) {
        //this.mark = 0 + 1
        this.mark = this.mark + add
        console.log("mark为:",this.mark)  
      }
    }
  }
</script>
<style lang='scss'>
.show{
  text-align:center;
  height:266px;
  background: #EA5149;
  margin-bottom:5px;
  color: #FFFFFF;
  font-weight:bold;
  .mark-text{
    font-size: 20px;
    padding:28px;
  }
  .mark{
    font-size: 88px;
  }
  .button{
    margin:0 10px;
    height: 30px;
    line-height:30px;
    text-align:center;
    font-size: 15px;
    font-weight:bold;
    background:#EA5149;
    .btn0{
      width: 60px;
      border-radius: 15px;
      border:1px dashed #feb600;
    }
    .btn1{
      width: 60px;
      border-radius: 15px;
      border:1px dashed #feb600;
    }
  }
}
.row{
  margin: 40px 56px;
  .button{
    width: 70px;
    height: 70px;
    line-height:70px;
    border-radius: 20%;
    border: none;
    text-align:center;
    font-size: 25px;
    color:#FFFFFF;
    font-weight:bold;
  }
  .right{
    background:#EA5149;
    float: right;
  }
  .left{
    background:#feb600;
    margin-right:80px;
  }
}
</style>


最后将index.vue文件中的代码贴出来,大家对比一下,自己添加的是否正确

目录
相关文章
|
7月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
921 0
|
8月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1146 78
|
7月前
|
JavaScript 前端开发 UED
Vue 手风琴实现的三种常用方式及长尾关键词解析
手风琴效果是Vue开发中常见的交互组件,可节省页面空间、提升用户体验。本文介绍三种实现方式:1) 原生Vue结合数据绑定与CSS动画;2) 使用Element UI等组件库快速构建;3) 自定义指令操作DOM实现独特效果。每种方式适用于不同场景,可根据项目需求选择。示例包括产品特性页、后台菜单及FAQ展示,灵活满足多样需求。附代码示例与资源链接,助你高效实现手风琴功能。
428 10
|
7月前
|
JavaScript 前端开发 UED
Vue 表情包输入组件实现代码及详细开发流程解析
这是一篇关于 Vue 表情包输入组件的使用方法与封装指南的文章。通过安装依赖、全局注册和局部使用,可以快速集成表情包功能到 Vue 项目中。文章还详细介绍了组件的封装实现、高级配置(如自定义表情列表、主题定制、动画效果和懒加载)以及完整集成示例。开发者可根据需求扩展功能,例如 GIF 搜索或自定义表情上传,提升用户体验。资源链接提供进一步学习材料。
379 1
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
3229 65
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
10月前
|
人工智能 小程序 前端开发
【一步步开发AI运动小程序】十九、运动识别中如何解析RGBA帧图片?
本文介绍了如何将相机抽取的RGBA帧图像解析为`.jpg`或`.png`格式,适用于体测、赛事等场景。首先讲解了RGBA图像结构,其为一维数组,每四个元素表示一个像素的颜色与透明度值。接着通过`uni.createOffscreenCanvas()`创建离屏画布以减少绘制干扰,并提供代码实现,将RGBA数据逐像素绘制到画布上生成图片。最后说明了为何不直接使用拍照API及图像转换的调用频率建议,强调应先暂存帧数据,运动结束后再进行转换和上传,以优化性能。
|
11月前
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
308 4
|
Serverless 对象存储 人工智能
智能文件解析:体验阿里云多模态信息提取解决方案
在当今数据驱动的时代,信息的获取和处理效率直接影响着企业决策的速度和质量。然而,面对日益多样化的文件格式(文本、图像、音频、视频),传统的处理方法显然已经无法满足需求。
475 4
智能文件解析:体验阿里云多模态信息提取解决方案
|
JSON 小程序 UED
微信小程序 app.json 配置文件解析与应用
本文介绍了微信小程序中 `app.json` 配置文件的详细
1833 12

热门文章

最新文章

推荐镜像

更多
  • DNS