uni-app(优医咨询)项目实战 - 第2天

学习目标:

  • 掌握WXML获取节点信息的用法

  • 知道如何修改 uni-ui 扩展组件的样式

  • 掌握 uniForm 表单验证的使用方法

  • 能够在 uni-app 中使用自定义字体图标

一、uni-app 基础知识

uni-app 是组合了 Vue 和微信小程序的相关技术知识,要求大家同时俱备 Vue 和原生小程序的开发基础。

1.1 节点信息

在此再次强调一下原生小程序中并没有 DOM 操作相关的内容,也因此在 uni-app 中也是无法对 DOM 进行操作的,但在实际开发过程中是有获取节点信息,如宽高、位置等信息的需求的,这一节就来学习在 uni-app 中如何获取节点的宽高及位置等信息。

1.1.1 创建查询器

在网页中可以直接使用 document.querySelector 来查找 DOM 节点,在 uni-app 或小程序中则没有这样一个方法,取而代之的是调用 API uni.createSelectorQuery 创建一个查询实例(查询器),进而调用该实例的方法来查询页面中的节点元素。

<!-- pages/wiki/index.vue -->
<script setup> import { onMounted } from 'vue' // 在生命周期中调用 onMounted(() => {   // 节点查询器(实例)   const selectorQuery = uni.createSelectorQuery()console.log(selectorQuery)})
</script>
​
<template> <view class="container">   <view class="box">获取这个盒子的宽高、位置等信息</view> </view>
</template>
​
<style lang="scss"> page {   padding: 30rpx;}
​ .box {   width: 300rpx;   height: 300rpx;   margin-top: 40rpx;   background-color: pink;}
</style>
​

注意事项:

  1. 需要在 onMountedonReady 生命周期中调用

  2. 选择自定义组件中的节点时,需要调用 in 方法并传入当前页面实例(后面会例子来演示)

1.1.2 节点对象

在查询节点时分成 3 种情形,获取到的结果为节点信息对象(NodesRef)

  • select 根据选择器的要求,只查找符合条件的第一个节点,结果是一个对象

  • selectAll 根据选择器的要求,查找符合条件的全部节点,结果是一个对象数组

  • selectViewport 特指获取视口,查找视口的尺寸、滚动位置等信息

<script setup> import { onMounted } from 'vue'
​ onMounted(() => {   // 1. 节点查询器(实例)   const selectorQuery = uni.createSelectorQuery()      // 2. 查找节点
​   // 2.1 查找单个节点   selectorQuery.select('.box').boundingClientRect((rect) => {     // 获取宽高和位置     console.log(rect)   })
​   // 2.2 查找全部节点   selectorQuery.selectAll('.box').boundingClientRect((rects) => {     // 获取宽高和位置     console.log(rects)   })
​   // 2.3 查找视口信息   selectorQuery.selectViewport().boundingClientRect((rect) => {     console.log(rect)   })
​   // 3. 执行请求结果   selectorQuery.exec()})
</script>
​
<template> <view class="container">   <view class="box">获取这个盒子的宽高、位置等信息</view>   <view class="box"> 类选择器名称一样的另一个盒子 </view> </view>
</template>
​
<style lang="scss"></style>

注意事项:

  1. 不执行 exec 方法,将获取不到任何的节点信息

  2. 有多个查询步骤时,在结尾只执行一次 exec 即可,避免重复查询

  3. exec 方法代表执行结束,因此务必保证最后再调用

1.1.3 节点信息

节点信息对象中包含了若干的信息,根据需要调用不同的方法进行获取:

  1. boundingClientRect 节点的宽高及位置,长度单位是 px

  2. scrollOffset 节点滚动的位置,仅支持 scroll-view 组件或页面( viewport)

<script setup> import { onMounted } from 'vue'
​ onMounted(() => {   // 1. 节点查询器(实例)   const selectorQuery = uni.createSelectorQuery()      // 2. 查找节点
​// 省略了部分代码
​   // 2.3 查找视口信息   selectorQuery.selectViewport().boundingClientRect((rect) => {     console.log(rect)   })      selectorQuery.selectViewport().scrollOffset((offset) => {     console.log(offset)   })
​   // 3. 执行请求结果   selectorQuery.exec()})
</script>
​
<template> <view class="container">   <view class="box">获取这个盒子的宽高、位置等信息</view>   <view class="box"> 类选择器名称一样的另一个盒子 </view> </view>
</template>
​
<style lang="scss"></style>

注意事项:

  1. 在获取元素的位置时是按已定位的祖先元素为参考,即大家平时理解的“子绝父相”方式

  2. 元素未定位时参视口(viewport)为参考

1.2 自定义组件

在 uni-app 中自定义组件的定义与 Vue 组件基本一致,不要参照原生小程序方式来定义组件。

1.2.1 easycom组件规范

easycom 是 uni-app 自定义的加载组件的规范,按该规范定义的组件可以实现自动导入,其规范要求如下:

  1. 安装在项目根目录的 components 目录下,并符合 components/组件名称/组件名称.vue

  2. 安装在 uni_modules 目录下,路径为 uni_modules/插件ID/components/组件名称/组件名称.vue

大家回忆一下扩展组件 uni ui 是不是就是在没有引入的情况下自动导入的,其原因就是符合 easycom 组件规范。

1.2.2 custom-tabs

标签页(tabs)的切换在开发中是经常会使用到的一种交互方式,【优医咨询】项目就用到这种交互方式,接下来我们自已封装一个标签页组件,按着 easycom 的规范创建组件目录及文件:

接下来将上次课中完成的 tabs 部分的布局代码迁移到当前组件中:

<view class="custom-tabs"> <view class="custom-tabs-bar active">   <text class="tabbar-text">关注</text> </view> <view class="custom-tabs-bar">   <text class="tabbar-text">推荐</text> </view> <view class="custom-tabs-bar">   <text class="tabbar-text">护肤</text> </view> <view class="custom-tabs-bar">   <text class="tabbar-text">减脂</text> </view> <view class="custom-tabs-bar">   <text class="tabbar-text">饮食</text> </view> <view class="custom-tabs-cursor"></view>
</view>
// 自定义tabbar
.custom-tabs { display: flex; position: relative; padding: 0 30rpx;
}
​
.custom-tabs-bar { height: 80rpx; line-height: 80rpx

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1410593.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

8 -- JavaSE总结

目录 Java语言发展 Java基础语法 Java流程控制 Java方法 Java数组 面向对象 异常 Java常用类 集合框架 IO流 多线程 网络编程 GUI Java SE&#xff08;Java Standard Edition&#xff0c;Java标准版&#xff09;是Java技术的核心和基础&#xff0c;也是Java ME和J…

JavaScript 动态网页实例 —— 日期时间应用

前言 日期和时间也是网站设计中不可或缺的重要内容。本章基于JavaScript中Date 对象的基本概念,介绍日期和时间的各种应用。鉴于其他章节已间接涉及部分内容,本章主要介绍各类不同时钟的设计,以及各种不同形式的时间的实现,同时,还涉及日历的设计和倒计时效果的实现。 本…

BeanFactory 源码浅析

BeanFactory 功能介绍 BeanFactory 是核心容器&#xff0c;负责管理 Bean 对象 BeanFactory 接口的功能只有一个 getBean() 方法BeanFactory 的实现类&#xff08;DefaultListableBeanFactory&#xff09;包含&#xff1a;控制反转、基本的依赖注入、Bean 生命周期的各种功能…

HR招聘面试时采用的在线人才测评,主要考察求职者哪些方面?

现如今的企业招聘求职者的时候&#xff0c;考察的方面是多样化的。以往很有可能只是考察求职者的业务能力&#xff0c;目前的大多数企业为了在竞争当中拥有更多的竞争力&#xff0c;企业人才测评的时候&#xff0c;往往更青睐于考察求职者多方面的能力。 对于求职者来说&#…

代码随想录算法训练营DAY48|C++动态规划Part9|121.买卖股票的最佳时机、122.买卖股票的最佳时机II、123.买卖股票的最佳时机III

文章目录 121.买卖股票的最佳时机思路CPP代码 122.买卖股票的最佳时机II思路CPP代码 123.买卖股票的最佳时机III思路CPP代码 121.买卖股票的最佳时机 力扣题目链接 文章讲解&#xff1a;121.买卖股票的最佳时机 视频讲解&#xff1a;动态规划之 LeetCode&#xff1a;121.买卖股…

【Mac】Lightroom Classic 2024 v13.1安装教程

软件介绍 Lightroom Classic 2024是Adobe公司推出的一款专业的数字图像处理软件&#xff0c;旨在为摄影师提供强大的工具和功能&#xff0c;以管理、编辑和分享他们的照片作品。以下是Lightroom Classic 2024的主要特点和功能&#xff1a; 数字照片管理&#xff1a; 提供直观…

如何在postman上提交文件格式的数据

如何在postman上提交文件格式的数据 今天在写一个文件上传的功能接口时&#xff0c;想用postman进行提交&#xff0c;花了些时间才找到在postman提交文件格式的数据。记录一下吧&#xff01; 1.打开postman&#xff0c;选择POST提交方式&#xff0c;然后在Params那一行的Head…

求职应聘找工作,如何看待企业在线人才测评

求职者面试的过程当中&#xff0c;除了要向求职的单位展现自身的业务能力之外&#xff0c;更需要展现其他方面的优势。企业人才测评对求职者存在哪些好处&#xff1f; 可能觉得参加测评只是面试的一部分&#xff0c;但是没有测评的情况下&#xff0c;求职者很有可能很难真正全…

【C++题解】1300. 小明暑假的零花钱

问题&#xff1a;1300. 小明暑假的零花钱 类型&#xff1a;多分支结构 题目描述&#xff1a; 小明同学的妈妈在期末考试之后决定根据小明的考试成绩奖励小明不同的暑假零花钱&#xff0c;如果考试成绩在90 分以上&#xff08;包括 90 分&#xff09;&#xff0c;零花钱是成绩…

2024.5.2

List容器实现 #include <iostream> #include <list> using namespace std;int main() {list<int> l1;l1.assign(1,13);cout << *l1.begin() << endl;cout <<l1.front() << endl;l1.assign(2,78);l1.insert(l1.end(),100);l1.push_b…

导数之光:探寻机器学习中的微变奥秘

在当今这个数据驱动的时代&#xff0c;机器学习以其强大的学习和预测能力&#xff0c;成为了推动科技进步的重要力量。而在机器学习的背后&#xff0c;数学原理&#xff0c;尤其是导数的应用&#xff0c;为其提供了坚实的理论支撑。本文将详细探讨导数在机器学习中的体现&#…

人工智能|推荐系统——工业界的推荐系统之概要

以小红书为例的推荐系统的转化流程&#xff0c;用户看到内容就是曝光&#xff0c;可以点击进去&#xff0c;然后进行一些“交互”行为&#xff0c;比如评论、点赞、收藏、转发。 通常会考虑用户的一些消费指标 而从推荐系统的角度则会考虑一些北极星指标&#xff0c;也就是优化…

CMake:嵌套的CMake与多级项目管理(八)

1、嵌套的CMake 如果项目很大或者项目中有很多的源码目录&#xff0c;在通过CMake管理项目的时候如果只使用一个CMakeLists.txt&#xff0c;那么这个文件会相对比较复杂&#xff0c;有一种化繁为简的方式就是给每个源代码目录都添加一个CMakeLists.txt文件&#xff08;头文件不…

Debian操作系统的常用指令介绍

Debian是一个流行的Linux操作系统&#xff0c;以其稳定性和安全性而闻名。对于Debian用户来说&#xff0c;掌握一些基本的命令行指令是非常重要的&#xff0c;因为它们可以帮助你更高效地管理系统。在这篇博客中&#xff0c;我们将介绍一些在Debian系统中常用的指令及其功能。 …

远程桌面报错:【出现验证错误。要求的函数不受支持】

WinR 输入【gpedit.msc】回车 依次打开 计算机配置----管理模板-----系统-----凭据分配---加密数据库修正 选择【已启用】&#xff0c;下拉菜单选择【易受攻击】

24.5.2数据结构|顺序表实现

主要是记笔记&#xff0c;留着以后复习回来看的&#xff0c;有些内容解释的并不清晰。也就稍微可以借鉴借鉴。 一、如何定义结构&#xff1f; 应该有的部分用来约束的部分 二、看书搞清楚顺序表实现流程 1、准备工作&#xff1a;如何定义结构体&#xff1f;SeqList&#xf…

每日一题(力扣213):打家劫舍2--dp+分治

与打家劫舍1不同的是它最后一个和第一个会相邻&#xff0c;事实上&#xff0c;从结果思考&#xff0c;最后只会有三种&#xff1a;1 第一家不被抢 最后一家被抢 2 第一家被抢 最后一家不被抢 3 第一和最后一家都不被抢 。那么&#xff0c;根据打家劫舍1中的算法 我们能算出在i…

【Java笔记】第5章:函数

前言1. 函数的理解2. 函数的基本使用3. 函数的参数4. 函数的返回值5. 函数的执行机制6. 函数的递归调用结语 ↓ 上期回顾: 【Java笔记】第4章&#xff1a;深入学习循环结构 个人主页&#xff1a;C_GUIQU 归属专栏&#xff1a;【Java学习】 ↑ 前言 各位小伙伴大家好&#xff…

java递归-(迷宫问题)

前面 这里我们来玩个有趣的事情&#xff0c;链接是0221_韩顺平Java_老鼠出迷宫1_哔哩哔哩_bilibili 我们要找的是小老鼠按路径走到右下点 要点 我们这里方法调用时对于引用类型&#xff1a;如java中引用数据类型有哪些&#xff1f;_java引用数据类型-CSDN博客 会共享引用类型…

浏览器安装路径位置的查看、指定网址快捷方式的创建

浏览器安装路径位置的查看、指定网址快捷方式的创建 浏览器安装路径位置的查看 法一、属性查看法 右键点击浏览器的桌面图标&#xff0c;选择“属性”&#xff0c;“快捷方式”页中的“目标”框中可见. 以Microsoft Edge浏览器为例&#xff0c;参见下图&#xff1a; 法二、地…