关于avm.js:YonBuilder移动开发平台-AVM框架-封装虚拟数字键盘组件

3次阅读

共计 7470 个字符,预计需要花费 19 分钟才能阅读完成。

AVM(Application-View-Model)前端组件化开发模式基于规范 Web Components 组件化思维,提供蕴含虚构 DOM 和 Runtime 的编程框架 avm.js 以及多端对立编译工具,齐全兼容 Web Components 规范,同时兼容 Vue 和 React 语法糖编写代码,编译工具将 Vue 和 React 相干语法糖编译转换为 avm.js 代码。

基于规范 Web Components 组件化思维,兼容 Vue / React 语法个性,通过一次编码,别离编译为 App、小程序代码,实现多端开发。

组件性能介绍
虚构数字键盘,反对数字随机,反对自定义输入数字内容的长度,自定义是否反对双向绑定,反对二次输出操作。能够为明码、验证码输出时应用。

示例展现

组件开发
组件文件

number-keyboard.stml

<template>

<view class="number-keyboard_container">

 <view class="number-keyboard_box">

  <view class="number-keyboard_box-item-container">

   <view class="number-keyboard_box-item" v-for="item in numbers">

    <view class="number-keyboard_box-item-label" data-key={item} @click="getNumber">

     <text style="font-size:28px;">{item}</text>

    </view>    

   </view>

   <view class="number-keyboard_box-item">    

    <view class="number-keyboard_box-item-label" @click="closeBoard">

     <image class="number-keyboard_box-item-ico" src={closeBase64} mode="widthFix"></image>

    </view>

   </view>

   <view class="number-keyboard_box-item">

    <view class="number-keyboard_box-item-label" data-key='0' @click="getNumber">

     <text style="font-size:28px;">0</text>

    </view>    

   </view>

   <view class="number-keyboard_box-item">  

    <view class="number-keyboard_box-item-label" @click="delNumber">

     <image class="number-keyboard_box-item-ico" src={backBase64} mode="widthFix"></image>

    </view>  

   </view>    

  </view>

 </view>

</view>

</template>

<script>

export default {

 name: 'number-keyboard',

 props:{

  limitLengh:Number,

  recnetNumber:Array,

  isRandom:Boolean,

  isModel:Boolean

 },

 installed(){if(this.props.isRandom){this.data.numbers.sort(this.randomsort);

  }

  if(this.props.isModel){

   this.data.resultNumber=this.props.recnetNumber;

   this.data.numberIndex = this.props.recnetNumber.length;

  }  

 },

 data() {

  return{numbers:['1','2','3','4','5','6','7','8','9'],

   resultNumber:[],

   numberIndex:0,

   closeBase64:'',

   backBase64:''

  }

 },

 methods: {randomsort(a,b){return Math.random()>0.5 ? -1 : 1;// 用 Math.random()函数生成 0~1 之间的随机数与 0.5 比拟,返回 - 1 或 1},

  closeBoard(e){this.fire('close','');

  },

  getNumber(e){if(this.props.isModel){if(this.data.numberIndex<this.props.limitLengh){this.data.resultNumber[this.data.numberIndex] = e.currentTarget.dataset.key;// 兼容 IOS 和安卓

     this.data.numberIndex += 1;

     this.fire('setNumber',this.data.resultNumber);

    }

   }

   else{this.fire('setNumber',[e.currentTarget.dataset.key]);

   }

   

  },

  delNumber(e){if(this.props.isModel){

    this.data.numberIndex -= 1;

    if(this.data.numberIndex>=0){this.data.resultNumber.splice(this.data.numberIndex,1);

     this.fire('setNumber',this.data.resultNumber);

    }

   }

   else{this.fire('delNumber','');

   }      

  }

 }

}

</script>

<style>

.number-keyboard_container {

 position: absolute;

 height: 100%;

 width: 100%;

 background-color: rgba(0,0,0,0);

}

.number-keyboard_box{

 align-items: center;

 position: absolute;

 bottom: 0;

 width: 100%;

 background-color: #cccccc;

}

.number-keyboard_box-item-container{

 flex-flow:  row wrap;

 justify-content: space-around;

 align-items: center;

 padding: 10px;

}

.number-keyboard_box-item{

 flex-basis: 33%;

    box-sizing: border-box;

 padding: 5px;

}

.number-keyboard_box-item-label{

 display: flex;

 background-color: #ffffff;

 padding: 5px;

 border-radius: 5px;

 width: 100%;

 height: 48px;

 align-items: center;

 justify-content: center;

}

.number-keyboard_box-item-ico{width: 60px;}

</style>


组件应用阐明
本组件是基于 AVM.js 开发的多端组件,通常同时适配 Android、iOS、小程序、H5 , 具体反对状况还要看每个组件的阐明文档。

首先须要登录开发平台,。通过管制平台右上方的模块 Store 进入,而后抉择 AVM 组件。

找到对应模块进入

也可通过搜寻栏,通过组件名称关键字进行检索。

进入模块详情,点击立刻下载下载残缺的组件安装包。

组件压缩包的文件目录如下

也可通过查看模块文档 来理解模块的具体参数,援用的原生模块,注意事项等。

具体在我的项目中的应用步骤是,第一步将压缩文件中的 number-keyboard.stml 文件拷贝到我的项目的 components 目录,通过浏览 readme.md 文档和查看 demo 示例文件 demo-number-keyboard.stml 在须要开发的 stml 文件中,引入组件文件,实现页面的开发。

对于随机数字键盘的原理是使用了数组的 sort 排序。

sort() 办法,有一个可选参数,必须是函数,供它调用。那么就是个回调函数咯!😁

回调函数的参数要有两个:第 2 个参数的元素必定在第 1 个参数的元素后面!

这个办法的排序是看回调函数的返回值:

如果返回值大于 0,则地位调换。

如果返回值小于 0,则地位不变。

第一次比拟:7>9,后果为 false,即 return -1,此时 a 会换到 b 后面,即 7 在 9 之前,所以地位调换。

demo-number-keyboard.stml

<template>

<view class="page">

 <safe-area></safe-area>

 <text class="number-box" @click="openNumberBoard">{isModel?'反对':'不反对'}双向绑定:{number}</text>

 <number-keyboard

  :limitLengh="limit"

  :recnetNumber="arrNumber"

  :isRandom="isRandom"

  :isModel="isModel"

  onclose="closeNumberBoard"

  onsetNumber="getNumber"

  ondelNumber="deleteNumber"

  v-if="isShowNUmberBoard">

  </number-keyboard>

</view>

</template>

<script>

import '../../components/number-keyboard.stml'

export default {

 name: 'demo-random-number-keyboard',

 apiready(){//like created},

 data() {

  return{

   isShowNUmberBoard:false,

   number:'',

   arrNumber:[],

   limit:6,

   isRandom:false,

   isModel:false  // 是否反对双向绑定

  }

 },

 methods: {closeNumberBoard(e){this.data.isShowNUmberBoard = false;},

  openNumberBoard(e){this.data.isShowNUmberBoard = true;},

  getNumber(e){// console.log(JSON.stringify(e));

   this.data.arrNumber = e.detail;

   this.data.number = e.detail.join('');

  },

  deleteNumber(e){

   api.toast({msg:'点击回退、删除键'})

   // 可依据须要解决显示的内容

   this.data.number='';

  }

 }

}

</script>

<style>

.page {

 height: 100%;

 background-color: #ffffff;

}

.number-box{font-size: 20px;}

</style>

如果在 AVM 组件库中,没有找到理论我的项目中须要的组件,能够本人尝试封装组件。

​ ​这是组件化开发的在线文档地址​

正文完
 0