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

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 , 具体反对状况还要看每个组件的阐明文档。 ...

December 27, 2022 · 2 min · jiezi