微信小程序踩坑之实现计算功能并在Input组件中显示

话不多说,直接上干货。

首先借助微信自带的weui.wxss实现input组件左右显示,实现类似下图的界面。这不是本文的重点,需要的同学可自行搜素。

1. wxml代码段如下:

<view class="weui-cells weui-cells_after-title">
<view class="weui-cell weui-cell_input">
<view class="weui-cell_hd">
<view class="weui-label labelCss">
<text class="textCss" style="font-weight: bold;font-size: 20px">建筑物层数</text>
</view>
</view>
<view class="weui-cell_bd">
<input class="weui-input inputCss" style="font-weight: bold;font-size: 20px;color: darkorange;" placeholder-class="place-holder" placeholder="请输入层数" type="number" bindinput="cengshu"/>
</view>
</view>

<view class="weui-cell weui-cell_input">
<view class="weui-cell_hd">
<view class="weui-label labelCss">
<text class="textCss" style="font-weight: bold;font-size: 20px">建筑物层高/m</text>
</view>
</view>
<view class="weui-cell_bd">
<input class="weui-input inputCss" style="font-weight: bold;font-size: 20px;color: darkorange;" placeholder-class="place-holder" placeholder="请输入层高" bindinput="cenghigh"/>
</view>
</view>


 <!--按钮-->
 <view class="JisuanBthView"> 
  <button class="JisuanBtn" type="primary" size="{{primarySize}}" loading="{{loading}}" disabled="{{disabled}}" bindtap="Jisuan">计 算</button> 
 </view> 


<view class="weui-cells weui-cells_after-title" style="margin-top: 10px;">
<view class="weui-cell weui-cell_input">
<view class="weui-cell_hd">
<view class="weui-label labelCss">
<text class="textCss" style="color: #AAAAAA;margin: auto;">总高/m</text>
</view>
</view>
<view class="weui-cell_bd">
<input class="weui-input inputCss" placeholder-class="place-holder" style="font-weight: bold;font-size: 20px;" disabled="{{isDisabled}}" placeholder="{{Zg}}"/>
</view>
</view>


</view>

2. JS代码段如下:

const app = getApp()
var Cs = null;//变量,用于存放建筑物层数
var Cg = null;//变量,用于存放建筑物层高

Page({

  /**
   * 页面的初始数据
   */
  data: {
    isDisabled:true,
    Zg:"",//总高
   },

  //建筑物层数
    cengshu:function(e) {
    Cs=e.detail.value;
    Cs=parseInt(Cs);
    },
   //建筑物层高
   cenghigh:function(e) {
     Cg=e.detail.value;
     Cg=parseInt(Cg);
   },


      Jisuan(){
 
          this.setData({
            isDisabled:false,
            Zg:Cs*Cg,
          });
        this.setData({
          isDisabled:true,
        })

    },

})

重点来了,有以下几个点要关注:

(1) 一定要有  =parseInt(),因为输入的是字符,需要转化为整型才能计算;

(2)WXML界面的disabled="{{isDisabled}}",与JS界面的  data: {isDisabled:true}呼应,是为了实现计算结束后,input失效以保证运行后,结果不能被更改。

(3)WXML采用placeholder="{{Zg}}",是同时实现显示,为后续计算提供方面。

谢谢大家,我是疯狂的豆包,请关注我,带你体验疯狂的编程乐趣。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疯狂的豆包

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值