微信小程序的常用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跳转的按钮后,页面显示为

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Qt的qtmqtt库连接onenet出现QMQTT::SocketRemoteHostClosedError解决方法

问题描述 在Qt发开过程中使用qtmqtt库来连接onenet的mqtt服务器&#xff0c;在ClientId、Username和Password均填写正确的情况下还是连接不上&#xff0c;查看错误显示QMQTT::SocketRemoteHostClosedError。 解决方法 client中的CleanSession标志位必须设置为true。 client …

分子动力学模拟学习-Gromacs工具链

1、总体流程 在gromacs的使用说明中有一个flow chart&#xff0c;比较简略。以下针对一般体系&#xff08;非蛋白等领域&#xff09;进行了一些调整&#xff0c;通用性更强。 在做分子动力学模拟时&#xff0c;其复杂性除了以上各种输入输出文件的操作&#xff0c;另一点就是力…

眼图仪参数理解和一些测量指标

参考资料&#xff1a; https://www.eet-china.com/mp/a35960.html 一&#xff1a;关于眼图仪&#xff1a; :::warning ●如果追溯历史&#xff0c;大约47年前&#xff0c;眼图就已经开始广泛应用。在1962年-2002的40年间&#xff0c;眼图的测量方法是基于采样示波器的传统方法…

3GPP相关资料收集整理

1、3GPP介绍 主页&#xff1a;3GPP – The Mobile Broadband Standard 3GPP(3rd Generation Partnership Project,第三代合作伙伴计划)成立于1998年12月&#xff0c;多个电信标准组织伙伴共同签署了《第三代伙伴计划协议》。3GPP最初的工作范围是为第三代移动通信系统制定全球适…

IDEA实现Springboot项目自动热部署

每当我们在修改代码时&#xff0c;往往需要重新启动项目&#xff0c;这样不仅浪费时间而且很麻烦&#xff0c;我们可以通过IDEA的热部署来提高效率 1、首先点file >> settings >> Build Excution >> Compire&#xff0c;选择Build project auto matically 2.…

linux kernel内存泄漏检测工具之slub debug

一、背景 slub debug 是一个debug集&#xff0c;聚焦于kmem_cache 分配机制的slub内存&#xff08;比如kmalloc&#xff09;&#xff0c;这部分内存在内核中使用最频繁&#xff0c;slub debug其中有相当部分是用来处理内存踩踏&#xff0c;内存use after free 等异常的&#x…

虚良SEO多口子权重蜘蛛池怎么正确使用

一、蜘蛛池的工作原理 蜘蛛池的核心在于通过大量的页面和内容&#xff0c;提高网站的搜索引擎排名&#xff0c;从而获得更多的流量和曝光机会。这种策略通常被用于网站推广和SEO优化。通过将网站链接发布到蜘蛛池中&#xff0c;可以增加网站的曝光率&#xff0c;吸引更多的搜索…

数据结构与算法--稀疏数组

1.引入 比如在编写五子棋时要实现存盘退出和继续上盘的功能。 如果使用二维数组来记录&#xff0c;每行每列&#xff0c;白子对应2&#xff0c;黑子对应1&#xff0c;默认值对应0.然后这里黑子对应二维数组a[1][2]。白子对应二维数组a[2][3]。 如果棋子很少&#xff0c;那么这…

AtCoder Regular Contest 176 C. Max Permutation(计数 分类讨论)

题目 思路来源 乱搞ac 题解 1. 如果有边的权值是1&#xff0c;意味着有两个点的权值都是1&#xff0c;无解 2. 如果一个点i被多个max条件控制&#xff0c;它的值不能超过这些max里最小的那个&#xff0c;记做up[i] 3. 如果同一个权值w对应的边不少于2条&#xff0c;这些边…

Spring Task学习记录

介绍 cron表达式 cron表达式在线生成器 链接: link 入门案例 Component Slf4j public class MyTask {/*** 定时任务 每隔5秒触发1次*/Scheduled(cron "0/5 * * * * ?")public void executeTask(){log.info("定时任务开始执行&#xff1a;{}", new Date…

AtCoder Beginner Contest 173 F - Intervals on Tree(计数 树的性质 贡献)

题目 思路来源 洛谷题解AT_abc173_f Intervals on Tree 题解 - 洛谷专栏 题解 一棵树&#xff0c;考虑加边的过程&#xff0c;加一条边减少一个连通块 那么&#xff0c;逆向这个过程&#xff0c;没删一条边&#xff0c;就多一个连通块 树&#xff1a;点的个数边的个数1 森…

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

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

JavaEE——介绍 HTTPServlet 三部分使用与 cookie 和 session 的阐述

文章目录 一、HTTPServlet介绍其中的关键 三个方法 二、HTTPServletRequest(处理请求)1.分块介绍方法作用get 为前缀的方法字段中 含有 getParameter 字段 的方法(前后端交互)&#xff1a;字段中 含有 getHeader 字段 的方法&#xff1a; 2.解释前后端的交互过程3.使用 json 格…

科技感十足特效源码

源码介绍 科技感十足特效源码&#xff0c;源码由HTMLCSSJS组成&#xff0c;记事本打开源码文件可以进行内容文字之类的修改&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面 源码截图 源码下载 科技感十足特效源码

Python_AI库 Matplotlib的应用简例:绘制与保存折线图

本文默认读者已具备以下技能&#xff1a; 熟悉Python基础语法&#xff0c;以自行阅读python代码块熟悉Vscode或其它编辑工具的应用 在数据可视化领域&#xff0c;Matplotlib无疑是一个强大的工具。它允许我们创建各种静态、动态、交互式的可视化图形&#xff0c;帮助我们更好…

pyaibote--安卓自动化环境配置与基础的使用方法

前言 欢迎来到我的博客 个人主页:北岭敲键盘的荒漠猫-CSDN博客 pyaibote介绍 pyaibote是一个全新&#xff0c;强大的办公自动化库。 支持找图&#xff0c;识别像素等操作。 比appium快十倍。 文章介绍 有大佬给我提到这个库后&#xff0c;我来查看。然后发现这个库太新了&am…

Coursera: An Introduction to American Law 学习笔记 Week 04: Constitutional Law

An Introduction to American Law 本文是 https://www.coursera.org/programs/career-training-for-nevadans-k7yhc/learn/american-law 这门课的学习笔记。 文章目录 An Introduction to American LawInstructors Week 04: Constitutional LawKey Constitutional Law TermsSup…

redission原理笔记

加锁成功的线程&#xff0c;将UUID和线程id和key绑定&#xff0c; 加锁成功后&#xff0c;内部有一个看门狗机制&#xff0c;每隔十秒看下当前线程是否还持有锁&#xff0c;延长生存时间。 没有获取锁的就一直自旋等待&#xff0c;直到超时。 如果redis是主从同步的&#xff0…

Android Studio gradle 默认sourceSets配置

一. AS默认的sourceSets配置 sourceSets在Android插件中如何使用的&#xff1a;android {sourceSets {main {manifest.srcFile AndroidManifest.xmljava.srcDirs [src]resources.srcDirs [src]aidl.srcDirs [src]renderscript.srcDirs [src]res.srcDirs [res]assets.srcD…

Anti Rookit -- 检测隐藏进程

Anti Rookit 一&#xff1a;检测隐藏进程 引言 检测隐藏进程除了众所周知的枚举进程ID之外&#xff0c;还有枚举句柄表的方式。不过今天给大家带来的是第三种方法。 探究 应用层通过接口 C r e a t e P r o c e s s \textcolor{cornflowerblue}{CreateProcess} CreateProcess…