微信小程序的常用API②

一、动画API

(1)作用:用于在微信小程序中完成动画效果的制作

(2)使用:创建实例 wx.createAnimation()

(3)常用属性:

duration           【number型】 动画持续时间,单位毫秒,默认400毫秒

timingFunction 【string型】    动画效果 默认linear

delay                【number型】 动画延迟时间 单位毫秒,默认0

transformOrigin【string型】    设置旋转元素的基点位置,默认50% 50% 0 。这三个数字分别表示X轴、Y轴、Z轴位置

(4)timingFunction属性的属性值:

linear            匀速

ease             慢快慢

ease-in         以低速开始

ease-in-out   以低速开始和结束

ease-out       以低速结束

step-start      动画第一帧就跳至结束状态,直至结束

step-end        动画一直保持开始状态,最后一帧跳至结束状态

(5)常用方法:

rotate(number angle)                  旋转。顺时针。角度取值范围【-180,180】

export()                                       导出动画队列。export()方法每次调用后会清掉之前的动画操作

scale(number sx,number sy)     缩放。当仅有sx参数时,表示在X轴Y轴同时缩放sx倍

translate(number tx,number ty) 平移。单位为px

skew(number ax,number ay)     倾斜。角度取值范围【-180,180】

step(object,object)                     表示一组动画完成。当调用任意多个动画方法组成一组动画时,一组动画中的所有动画会同时开始,一组动画完成后才会进行下一组动画。

opacity(number value)                 设置透明度,范围0~1

backgroundColor(string value)    设置背景色

width(number|string value)          设置宽度

top(number|string value)             设置top值

(6)代码示例:

6-1》在index.wxml里
<navigation-bar title="Weixin" back="{{false}}" color="black" background="#FFF"></navigation-bar>
<!-- 一、Animation 动画API -->
<view animation='{{move}}'>hello world</view>
<button bind:tap="play">播放动画</button>
6-2》在index.js里
Pages({
//一、动画 Animation API 
play:function(){var animation=wx.createAnimation();animation.duration=4000;animation.timingFunction='ease';animation.translate(50,70).step();this.setData({move:animation.export()})}})
6-3》初始页面为:

6-4》添加动画效果后,点击按钮,文字将匀速移动到相应位置:

二、map地图组件

(1)作用:map地图组件可以为用户通过地图的功能。支持移动、缩放、添加标记点...

(2)使用:直接使用map标签即可  <map></map>

(3)常用属性:

longitude              【number】 中心经度,为必填项

latitude                 【number】 中心纬度,为必填项

scale                    【number】 缩放级别,取值范围为3-20,默认为16

markers                【Array.】 标记点数组

show-location       【boolean】 是否显示带有方向的当前定位点,默认false

bindregionchange 【eventhandle】 视野发生变化时触发的事件处理函数

(4)标记点属性——marker对象属性:

markers标记点数组中的每一项为一个表示标记点的marker对象

id             【number】 标记点id

longitude 【number】 经度。取值范围 -180~180 必填项

latitude    【number】 纬度。取值范围 -90~90 必填项

iconPath 【string】     设置标记点图标路径。必填项

title         【string】     标记点名字,点击时显示

zIndex    【number】  显示层级

alpha      【number】  标记点透明度,默认1,即无透明。取值0~1

width      【number/string】 标记点图标宽度

height    【number/string】 标记点图标高度

(5)代码示例:

5-1》在我的images里面存了gps.png图片

5-2》在index.wxml里
<navigation-bar title="Weixin" back="{{false}}" color="black" background="#FFF"></navigation-bar>
<!-- 二、map 地图组件 -->
<map id="myMap" scale="3" markers="{{myMarkers}}"></map>
5-3》在index.js里
Pages({
data:{myMarkers:[{ //标记点属性id:1,longitude:'112.59',latitude:'28.12',iconPath:'../../images/gps.png',width:'50px',height:'50px'}]},
})
5-4》初始页面为:

5-5》使用map地图组件的js代码后,页面为:

三、地图 API

(1)作用:地图API帮助我们实现获取地图某一位置的功能

(2)使用:地图API必须在map组件中才能使用。创建wx.createMapContext("地图组件id")实例

(3)常用属性:

iconPath  【string】 图标路径

success   【function】 接口调用成功的回调函数

fail           【function】 接口调用失败的回调函数

complete 【function】 接口调用结束的回调函数

(4)常用方法:

getCenterLocation() 获取当前地图中心的经纬度。返回GCJ-02坐标系

moveToLocation()    将地图中心移至当前定位点

(5)getCenterLocation()常用方法的常用属性:

iconPath 【string】    图标路径

success 【function】 接口调用成功的回调函数,通过其参数可以获取longitude经度和latitude纬度

fail           【function】 接口调用失败的回调函数

complete 【function】 接口调用结束的回调函数

(6)moveToLocation()常用方法的常用属性:

longitude  【number】 经度

latitude     【number】 纬度

success   【function】 接口调用成功的回调函数

fail            【function】 接口调用失败的回调函数

complete 【function】 接口调用结束的回调函数

(7)代码示例:

7-1》index.wxml页面:
<navigation-bar title="Weixin" back="{{false}}" color="black" background="#FFF"></navigation-bar>
<!-- 二、map 地图组件 -->
<map id="myMap" scale="3" markers="{{myMarkers}}"></map>
<!-- 三、地图API -->
<button bind:tap="getCenter">获取地图中心位置的经纬度</button>
7-2》index.js页面:
Pages({
data:{myMarkers:[{ //标记点属性id:1,longitude:'112.59',latitude:'28.12',iconPath:'../../images/gps.png',width:'50px',height:'50px'}]},
getCenter:function(){var m=wx.createMapContext('myMap');m.getCenterLocation({success:res=>{console.log(res.longitude+"___"+res.latitude);}})},
})
7-3》初始页面为

7-4》点击地图API按钮后,控制台输出为

四、位置API

(1)作用:获取当前的实时位置

(2)注意:使用 wx.getLocation 需要用户的地理位置授权,如果用户未授权,可能需要先调用 wx.authorize 进行授权请求。

对于正常上线需要更改隐私权限,下列只是理论与演示

(3)使用:

在app.json里面配置:

Pages({"requiredPrivateInfos": ["getLocation"],"permission": {"scope.userLocation": {"desc": "获取用户的实时位置"}}
})

再创建wx.getLocation()实例

(4)常用选项:

type        【string】 当前位置坐标类型。设为WGS84可返回GPS坐标,设为GCJ-02可以返回用于微信内置地图查看位置的坐标

success  【function】 接口调用成功的回调函数

fail           【function】 接口调用失败的回调函数

complete 【function】 接口调用结束的回调函数

(5)success()的参数(对象)常用属性:

wx.getLocation()方法的success()回调函数的参数是一个对象,该对象属性如下:

longitude 【number】 经度,取值 -180~180

latitude    【number】 纬度,取值 -90~90

speed      【number】 速度,单位m/s

altitude    【number】 高度,单位m

(6)代码示例:

6-1》index.wxml里面
<navigation-bar title="Weixin" back="{{false}}" color="black" background="#FFF"></navigation-bar>
<!-- 四、位置 API -->
<button bind:tap="getLoc">获取实时位置</button>
6-2》index.js里
Pages({
getLoc:function(){wx.getLocation({type:'gcj02',success:res=>{console.log(res);}})},
})
6-3》初始页面 

6-4》点击按钮后,获取你所在的实时位置

此处控制台输出略,可自行演示

五、路由API

(1)作用:实现页面跳转

(2)使用:

2-1》wx.navigateTo()

a跳到b,a页面还存在。在b页面按返回可回到a页面

2-2》wx.redirectTo()

a跳到b,a页面不存在

2-3》wx.switchTab(object)

跳转到tabar页面,并且关闭其他非tabar页面(也就是跳转到主页)

(3)代码示例:

3-1》前提配置:为了更清晰的显示路由API效果,此时配置一个list文件夹

list.wxml页面如下:
<navigation-bar title="另外一个页面" color="black" background="#FFF"></navigation-bar>
<view>我是路由跳转后的页面</view>

3-2》index.wxml页面
<navigation-bar title="Weixin" back="{{false}}" color="black" background="#FFF"></navigation-bar>
<!-- 五、路由 API -->
<button bind:tap="goto">跳转</button>

3-3》index.js页面
Pages({
goto:function(){wx.navigateTo({// 跳转并且携带参数url: '../list/list?id=1&myname=zhangsan',})}
})

3-4》点击index.wxml跳转的按钮后,页面显示为

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《C++学习笔记---入门篇2》---传值引用与传引用返回详解

先看这个程序&#xff0c;随着Count栈帧的销毁&#xff0c;会创建一个临时变量将n的值带回&#xff0c;可以实现我们的目的。 再看这个情况的时候&#xff0c;对于n来说他存放的位置在静态区&#xff0c;他不会随着函数栈帧的销毁而销毁&#xff0c;返回的时候依旧靠着临时变量…

Jmeter05:配置环境变量

1 Jmeter 环境 1.1 什么是环境变量&#xff1f;path什么用&#xff1f; 系统设置之一&#xff0c;通过设置PATH&#xff0c;可以让程序在DOS命令行直接启动 1.2 path怎么用 如果想让一个程序可以在DOS直接启动&#xff0c;需要将该程序目录配置进PATH 1.3 PATH和我们的关系…

Python脚本抢票【笔记】

Python脚本抢票【笔记】 前言版权推荐Python脚本抢票【Python】microsoft edge驱动器下载以及使用最后 前言 2024-4-17 18:19:15 以下内容源自《【笔记】》 仅供学习交流使用 版权 禁止其他平台发布时删除以下此话 本文首次发布于CSDN平台 作者是CSDN日星月云 博客主页是ht…

容器工作流

背景 目前某平台使用计算容器和解析容器&#xff0c;这两种容器目前通过rabbitmq消息来进行链接&#xff0c;形成容器工作流&#xff0c;使用容器工作流框架可以省去两个容器中间环节的控制&#xff0c;不需要再使用java代码对容器的操作&#xff0c;通过容器工作流框架即可控…

SpringMVC进阶(数据格式化以及数据校验)

文章目录 1.数据格式化1.基本介绍1.基本说明2.环境搭建 2.基本数据类型和字符串转换1.需求分析2.环境搭建1.data_valid.jsp首页面2.Monster.java封装请求信息3.MonsterHandler.java处理请求信息4.monster_addUI.jsp添加妖怪界面5.单元测试 3.保存妖怪信息1.MonsterHandler.java…

运维笔记:基于阿里云跨地域服务器通信(上)

运维笔记 阿里云&#xff1a;跨地域服务器通信&#xff08;上&#xff09; - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this a…

git变更远端仓库名之后如何修改本地仓库配置的另一种方法?(删remote指针、添加、绑定master)

背景 如果某个远端的仓库地址变化后&#xff0c;本地仓库可以修改对应的remote。 之前谈过几种方法&#xff0c;比如重新设置一个新的remote的指针&#xff0c;绑定到新地址。然后删除origin&#xff0c;然后把新指针mv到origin。比如直接seturl修改&#xff08;git remote se…

深度学习从入门到精通——词向量介绍及应用

词向量介绍 词向量&#xff08;Word embedding&#xff09;&#xff0c;即把词语表示成实数向量。“好”的词向量能体现词语直接的相近关系。词向量已经被证明可以提高NLP任务的性能&#xff0c;例如语法分析和情感分析。词向量与词嵌入技术的提出是为了解决onehot的缺陷。它把…

ESP32-S3的MQTT实战

昨天&#xff0c;我们讲了socket通信&#xff0c;当服务器和客户端建立起连接时&#xff0c;就可以互相通信了。在互联网应用大多使用WebSocket接口来传输数据。而在物联网的应用中&#xff0c;常常出现这种情况&#xff1a;海量的传感器&#xff0c;需要时刻保持在线&#xff…

微信小程序[黑马笔记]

简介 常用组件 视图组件 <!--pages/list/list.wxml--><scroll-view class"container1" scroll-y><view>A</view><view>B</view><view>A</view></scroll-view><!--pages/list2/list.wxml--><swiper …

❤mac使用Idea工具

❤mac使用Idea工具 1、安装 直接跳过&#xff0c;文章有 &#xff08;点击跳转&#xff09; 给自己的mac系统上安装java环境 2、使用 快捷键 Command , 系统首选项 设置Idea连接数据库 打开右侧的database&#xff08;或菜单里&#xff09;连接数据库&#xff0c;根据提…

Ubuntu中的 Everything 搜索软件 ==> fsearch

本文所使用的 Ubuntu 系统版本是 Ubuntu 22.04 ! 在 Windows 中&#xff0c;我经常使用 Everything 来进行文件搜索&#xff0c;搜索效率比 Windows 自带的高出千百倍。 那么在 Ubuntu 系统中&#xff0c;有没有类似的软件呢&#xff1f;那必须有&#xff0c;它就是 FSearch 。…

安防监控/智能分析EasyCVR视频汇聚平台海康/大华/宇视摄像头国标语音GB28181语音对讲配置流程

一、背景分析 近年来&#xff0c;国内视频监控应用发展迅猛&#xff0c;系统接入规模不断扩大&#xff0c;涌现了大量平台提供商&#xff0c;平台提供商的接入协议各不相同&#xff0c;终端制造商需要给每款终端维护提供各种不同平台的软件版本&#xff0c;造成了极大的资源浪…

libVLC 制作一款精美的播放器

1.简介 本文将简单介绍使用libVLC制作一款精美的播放器。 开发环境:Visual Studio + Qt插件。 Qt版本:Qt5.9。 libVLC版本:3.0.20。 以下是运行界面效果图:截取其中几张。 右键菜单,功能还是比较齐全。 2.ui界面构成 接下来简单介绍一下ui界面构成。 主界面由播放树…

Mac下使用homebrew管理多版本mysql同时启动

Mac下使用homebrew管理多版本mysql同时启动 思路 给每个版本分配不同的数据目录和配置文件即可 本文尝试了使用 brew 安装管理多个MySQL版本&#xff0c;同时运行、直接切换 安装 如果已有数据文件请自行备份以及使用 安装 mysql 5.7 brew install mysql5.7在 /opt/home…

开发 Chrome 浏览器插件入门

前言 简介 Chrome 插件是扩展 Chrome 浏览器的功能的软件程序。它们可以执行各种任务&#xff0c;例如阻止广告、增强隐私、添加新功能等等。 要开始编写 Chrome 插件&#xff0c;你需要掌握以下&#xff1a; 1.JavaScript语言 2.html 3.css 4.会使用chrome扩展开发手册…

Git系列:Git Branch 用法总结

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

Docker数据管理与Dockerfile镜像创建

前言 在容器化环境中&#xff0c;如何有效地管理和持久化数据成为了开发人员和运维团队面临的挑战之一&#xff1b;另一方面&#xff0c;镜像的创建是构建容器化应用的基础。优化的镜像设计可以提高部署效率和应用性能&#xff0c;减少资源消耗和运行成本。本文将介绍 Docker …

纯血鸿蒙APP实战开发——预渲染实现Web页面瞬开效果

介绍 为了便于大家在使用本案例集时能够更详细的了解各个案例&#xff0c;本案例基于Web预渲染实现了案例介绍功能&#xff0c;即应用右下角的问号icon。 效果图预览 使用说明 因为直接加载的线上README&#xff0c;因此本功能需联网使用点击icon&#xff0c;即会弹出对应案…

后端端口也可以直接在浏览器访问

比如在浏览器输入http://localhost:8078/hello/helloword访问的是后端的 RestController RequestMapping("/hello") public class HelloWord {RequestMapping("/helloword")public String helloWord(){return "hello word";} }浏览器将会返回