09 微信小程序中 一些封装的函数

变速改变任意对象的任意属性大小的动画函数:

 1   //变速改变任意对象的任意属性大小的函数
 2   animation_variableSpeed: function (ele, ele_tar, func_callback) {  //ele 对象  attr 属性名字 targetPos 目标位置 func_callbk回调函数
 3     var that = this;
 4     var len = Object.getOwnPropertyNames(ele_tar).length;  //它是获取ele_tar对象中 有多少个字段。
 5     //清理定时器
 6     clearInterval(ele.timeId);
 7     ele.timeId = setInterval(function () {
 8       for (var key in ele_tar) {
 9         var attr = key;
10         var targetPos = ele_tar[key];
11
12         if (attr == "opacity") { //透明度属性
13           //此时的 透明度的精度设计是 0.01
14           var curPos = parseInt( ele.opacity * 100); //透明度放大100倍方便计算(此时类型是数字类型)
15           var targetPos = parseInt(ele_tar[attr] * 100);  //目标透明度也放大100倍
16
17           var step = (targetPos - curPos) / 10;
18           step = step > 0 ? Math.ceil(step) : Math.floor(step);
19           curPos += step;
20
21           ele[attr] = curPos / 100;  //最后赋值的时候也要缩小100倍
22           console.log("cur: " + curPos + " tar:" + targetPos + " step:" + step + " ");
23
24         } else if (attr == "zIndex") { //层次的属性
25           ele[attr] = ele_tar[attr];
26
27         } else {  //普通的属性
28           //获取当前的位置
29           var curPos = parseInt(ele[attr]);
30           //每次移动的步数
31           var step = (targetPos - curPos) / 10;
32           step = targetPos > curPos ? Math.ceil(step) : Math.floor(step); //正数向上取整 负数向下取整
33           curPos += step;
34           ele[attr] = curPos;
35           console.log("cur: " + curPos + " tar:" + targetPos + " step:" + step + " ");
36         }
37
38
39         var flag = true; // 清理定时器
40         for (var key in ele_tar) {
41           var attr = key;
42           if( ele[attr] != ele_tar[attr] ){
43               flag = false;
44           }
45         }
46         if(flag){
47           console.log("清理定时器")
48           clearInterval(ele.timeId);
49           //所有的属性都更改完毕之后再调用回调函数!
50           if (func_callback) { //有 callbk 才可以调用
51             func_callback();
52           }
53         }
54       }
55       that.setData({ele:ele});
56     }, 15);
57   }

变速动态函数

1 <view style="width:{{ele.w}}px;height:{{ele.h}}px;opacity:{{ele.opacity}};z-index:{{ele.zIndex}}"></view>

index.wxml

  1 // pages/zcb/zcb.js
  2 Page({
  3
  4   /**
  5    * 页面的初始数据
  6    */
  7   data: {
  8
  9   },
 10
 11   /**
 12    * 生命周期函数--监听页面加载
 13    */
 14   onLoad: function (options) {
 15     var that = this;
 16     var ele = {
 17       w:300,
 18       h:0,
 19       opacity:1,
 20       zIndex:1,
 21     }
 22     this.setData({ele:ele});
 23
 24     // 需要改变的值
 25     var ele_tar = {
 26       w: 300,
 27       h: 300,
 28       opacity: 0.5,
 29       zIndex: 1,
 30     }
 31     var ele_tar2 = {
 32       w:0,
 33       h:300,
 34       opacity:1,
 35       zIndex:1
 36     }
 37     this.animation_variableSpeed(ele,ele_tar,function(){
 38       that.animation_variableSpeed(ele,ele_tar2)
 39     });
 40
 41   },
 42   //变速改变任意对象的任意属性大小的函数
 43   animation_variableSpeed: function (ele, ele_tar, func_callback) {  //ele 对象  attr 属性名字 targetPos 目标位置 func_callbk回调函数
 44     var that = this;
 45     var len = Object.getOwnPropertyNames(ele_tar).length;  //它是获取ele_tar对象中 有多少个字段。
 46     //清理定时器
 47     clearInterval(ele.timeId);
 48     ele.timeId = setInterval(function () {
 49       for (var key in ele_tar) {
 50         var attr = key;
 51         var targetPos = ele_tar[key];
 52
 53         if (attr == "opacity") { //透明度属性
 54           //此时的 透明度的精度设计是 0.01
 55           var curPos = parseInt( ele.opacity * 100); //透明度放大100倍方便计算(此时类型是数字类型)
 56           var targetPos = parseInt(ele_tar[attr] * 100);  //目标透明度也放大100倍
 57
 58           var step = (targetPos - curPos) / 10;
 59           step = step > 0 ? Math.ceil(step) : Math.floor(step);
 60           curPos += step;
 61
 62           ele[attr] = curPos / 100;  //最后赋值的时候也要缩小100倍
 63           console.log("cur: " + curPos + " tar:" + targetPos + " step:" + step + " ");
 64
 65         } else if (attr == "zIndex") { //层次的属性
 66           ele[attr] = ele_tar[attr];
 67
 68         } else {  //普通的属性
 69           //获取当前的位置
 70           var curPos = parseInt(ele[attr]);
 71           //每次移动的步数
 72           var step = (targetPos - curPos) / 10;
 73           step = targetPos > curPos ? Math.ceil(step) : Math.floor(step); //正数向上取整 负数向下取整
 74           curPos += step;
 75           ele[attr] = curPos;
 76           console.log("cur: " + curPos + " tar:" + targetPos + " step:" + step + " ");
 77         }
 78
 79
 80         var flag = true; // 清理定时器
 81         for (var key in ele_tar) {
 82           var attr = key;
 83           if( ele[attr] != ele_tar[attr] ){
 84               flag = false;
 85           }
 86         }
 87         if(flag){
 88           console.log("清理定时器")
 89           clearInterval(ele.timeId);
 90           //所有的属性都更改完毕之后再调用回调函数!
 91           if (func_callback) { //有 callbk 才可以调用
 92             func_callback();
 93           }
 94         }
 95       }
 96       that.setData({ele:ele});
 97     }, 15);
 98   }
 99
100
101 })

index.js

1 view{
2   background-color: purple;
3 }

index.wxss

原文地址:https://www.cnblogs.com/zach0812/p/12302727.html

时间: 2024-08-30 14:03:31

09 微信小程序中 一些封装的函数的相关文章

微信小程序中的循环遍历问题

比如:如果在微信小程序中要遍历输出 0-9 的数,我们会使用for循环 for(var i=0;i<10;i++){ console.log(i); } 确实结果也是这样: 但是,如果我在循环时同时调用wx的api接口10次,那么输出的结果就会不同(这是产生了闭关的效应) eg:每次调用一次wx.showToast()接口,并在成功时输出循环的值. for(var i=0;i<10;i++){ wx.showToast({ title: 'haha', success:function(){

在微信小程序中使用redux

本文主要讲述,在微信小程序中如何使用redux DEMO 需要解决的问题 如何在小程序中引入redux状态管理库,及它相关的插件? 微信小程序没有清晰的异步api,便于thunkMiddleware处理异步请求(异步操作),如何解决? 如何正确使用store的三大核心方法(getStore dispatch subscribe)? redux并不是react专属,所以他可以在任何地方使用,小程序也不例外.解决上面三个问题就可以了. 问题一: 如何在小程序中引入redux状态管理库,及它相关的插件

在微信小程序中使用LeanCloud(一)

之前学习了微信小程序前端,使用到LeanCloud线上数据库 [传送门].作为一个前端开发人员,了解后端及数据库是学习工作的需要. LeanCloud直接登录,未注册直接创建账户.它是一款免费的线上数据库(开发版免费).适用于一些想自己写微信小程序前端但不太会后端的开发者学习用.本篇文章涉及数据存储服务(增删查改). 首先,下载一个JavaScript-sdk :av-weapp-min.js[下载链接],它是在微信小程序中使用此数据库的关键文件.下载之后,保存至项目路径,这里以'/libs/a

微信小程序中target与currentTarget

如有错误,请纠出,大家一起进步!!! target在事件流的目标阶段:currentTarget在事件流的捕获,目标及冒泡阶段.但事件流处于目标阶段,target与currentTarget指向一样, 而当处于捕获和冒泡阶段的时候,target指向被单击的对象而currentTarget指向当前事件活动的对象.在微信小程序中也可总结为:target指向发生事件的组件,currentTarget指向绑定事件的组件. 下面请看例子: text.wxml: <view class="view1&

微信小程序中的 hover-class

微信小程序中,可以用 hover-class 属性来指定元素的点击态效果.但是在在使用中要注意,大部分组件是不支持该属性的. 目前支持 hover-class 属性的组件有三个:view.button.navigator. 不支持 hover-class 属性的组件,同时也不支持 hover-stop-propagation.hover-start-time.hover-stay-time 这三个属性. 使用方法: <view hover-class="bg_red">这是

微信小程序中的单位

vw:viewpoint width,视窗宽度,1vw等于视窗宽度的1%. vh:viewpoint height,视窗高度,1vh等于视窗高度的1%. rpx:rpx单位是微信小程序中css的尺寸单位,rpx可以根据屏幕宽度进行自适应.规定屏幕宽为750rpx.如在 iPhone6 上,屏幕宽度为375px,共有750个物理像素,则750rpx = 375px = 750物理像素,1rpx = 0.5px = 1物理像素. 微信小程序也支持rem尺寸单位,rem和rpx的换算关系:rem: 规

微信小程序中获取高度及设备的方法

由于js中可以采用操纵dom的方法来获取页面元素的高度,可是在微信小程序中不能操纵dom,经过查找之后发现仅仅只有以下几个方法可以获取到高度 wx.getSystemInfoSync().windowWidth // 获取当前窗口的宽度 wx.getSystemInfoSync().windowHeight // 获取当前窗口的高度 wx.getSystemInfoSync().model // 获取当前采用的设备 wx.getSystemInfoSync().pixelRatio wx.get

微信小程序中使用ECharts 异步加载数据 实现图表

<!--pages/bar/index.wxml--> <view class="container"> <ec-canvas id="mychart-dom-bar" canvas-id="mychart-bar" ec="{{ ec }}"></ec-canvas> </view> import * as echarts from '../../ec-canvas

微信小程序中转义字符的处理

在微信小程序开发过程中,有时候会用到常用的一些特殊字符如:'<'.'>'.'&'.'空格'等,微信小程序同样支持对转义字符的处理,下面提供两种方法用来处理微信小程序中转义字符的处理. 1.官方API调用这种方式,我们直接在wxml布局文件中,直接调用相关特殊符号的转义字符会无效,原因是小程序的text文本控件的decode属性没有打开导致的,看下文档说明: 从文档中,我们可以发现,decode属性默认为false,不会解析我们的特殊字符,我们通过设置decode属性为true,并且调用