小程序上实现房贷计算

  • 功能:实现房贷计算,区分等额本息,等额本金,查看月供详情
  • 效果图

组件

  • 存放路径 components/h-chosen

  • 使用 Vant Weapp:https://vant-contrib.gitee.io/vant-weapp/#/home

  • index.wxml

    <!-- components/h-chosen/index.wxml -->
    <view>
      <van-cell required="{{required}}" title="{{title}}" is-link bindclick="onClickCell">
        <view class="{{name ? 'main-color' : ''}}">
          {{name || '请选择'}}
        </view>
      </van-cell>
      <van-action-sheet show="{{ show }}" cancel-text="取消选择" actions="{{ actions }}" bind:close="onClose" bind:select="onSelect" bind:cancel="onCancel" />
    </view>
    
  • index.ts

      Component({
        /**
        * 组件的属性列表
        */
        properties: {
          actions: {
            type: Array,
            value: [],
          },
          value: {
            type: String,
            value: "",
          },
          title: {
            type: String,
            value: "标题",
          },
          required: {
            type: Boolean,
            value: false,
          },
          readonly: {
            type: Boolean,
            value: false,
          },
        },
    
        /**
        * 组件的初始数据
        */
        data: {
          name: "",
          show: false,
        },
    
        /**
        * 组件的方法列表
        */
        methods: {
          onClickCell() {
            this.triggerEvent("click");
            if(!this.properties.readonly) {
              this.setData({
                show: !this.data.show,
              });
            }
          },
    
          onClose() {
            this.setData({ show: false });
            this.triggerEvent("close");
    
          },
    
          onSelect(event:any) {
            this.triggerEvent("change", event.detail.value);
          },
          onCancel() {
            this.triggerEvent("change", '');
            this.setData({ show: false });
          }
        },
    
        observers: {
          "value,actions": function (value, actions) {
            const Id = String(value);
            let name = "";
            if (value && actions.length) {
              const find = actions.find((el: any) => {
                const elId = String(el.value);
                return elId === Id;
              });
              if (find) {
                name = find.name;
              }
            }
            this.setData({
              name: name || "",
            });
          },
        },
      });
    
  • index.scss

      .main-color {
        color: #333;
      }
    
  • index.json

      {
        "component": true,
        "usingComponents": {
          "van-cell": "@vant/weapp/cell/index",
          "van-cell-group": "@vant/weapp/cell-group/index",
          "van-action-sheet": "@vant/weapp/action-sheet/index"
        }
      }
    

房贷计算

  • mortgage/index

  • index.wxml

    <!--房贷计算-->
    <view class="mortgage-page">
      <van-cell-group>
        <HChosen title="贷款类型" data-key="form.loanType" actions="{{ loanList }}" value="{{ form.loanType }}" bind:change="onChangeName" />
        <block wx:if="{{form.loanType === 3}}">
          <van-field required title-width="160" type='digit' input-align="right" model:value="{{  form.accumulationTotal  }}" data-key="form.accumulationTotal" placeholder="请输入" bind:change="onChangeName" border="{{false}}">
            <view slot="label">
              公积金贷款金额<text class="color-999">(万元)</text>
            </view>
          </van-field>
          <HChosen title="公积金贷款年限" required data-key="form.accumulationYear" actions="{{ yearList }}" value="{{ form.accumulationYear }}" bind:change="onChangeName" />
          <van-field required title-width="140" type='digit' input-align="right" model:value="{{  form.accumulationRate  }}" data-key="form.accumulationRate" placeholder="请输入" bind:change="onChangeName" border="{{false}}">
            <view slot="label">
              公积金贷款利率<text class="color-999">(%)</text>
            </view>
          </van-field>
        </block>
        <van-field required title-width="140" type='digit' input-align="right" model:value="{{  form.total  }}" data-key="form.total" placeholder="请输入" bind:change="onChangeName" border="{{false}}">
          <view slot="label">
            {{form.loanType === 3 ? '商业贷款金额' : '贷款总额'}}<text class="color-999">(万元)</text>
          </view>
        </van-field>
        <HChosen title="贷款年限" required data-key="form.commercial" actions="{{ yearList }}" value="{{ form.commercial }}" bind:change="onChangeName" />
        <van-field required title-width="120"  type='digit' input-align="right" model:value="{{  form.rate  }}" data-key="form.rate" placeholder="请输入" bind:change="onChangeName" border="{{false}}">
          <view slot="label">
            利率<text class="color-999">(%)</text>
          </view>
        </van-field>
        <HChosen  title="还款方式" data-key="form.repaymentName" actions="{{ repaymentList }}" value="{{ form.repaymentName }}" bind:change="onChangeName" />
      </van-cell-group>
      <view class="mortgage-btn box-b">
        <van-button size="large" color="#a31f23" block bind:click="onSubmit">开始计算</van-button>
      </view>
    </view>
    
  • index.ts

      Page({
    
        /**
        * 页面的初始数据
        */
        data: {
          form: {
            loanType: 1, // 贷款类型
            calculationName: '', // 计算方式
            total: '', // 贷款金额
            commercial: '', // 商贷年限
            rate: '', // 利率
            repaymentName: '', // 还款方式
            accumulationTotal: '', // 公积金金额
            accumulationRate: '', // 公积金利率
            accumulationYear: '', // 公积金年限
          },
          loanList: [
            {
              value: 1,
              name: '商业'
            },
            {
              value: 2,
              name: '公积金'
            },
            {
              value: 3,
              name: '组合贷款'
            }
          ],
          calculationList: [
            {
              value: 1,
              name: '按贷款总额'
            },
            {
              value: 2,
              name: '按首月还款额计算'
            },
          ],
          repaymentList: [
            {
              value: '等额本息',
              name: '等额本息'
            },
            {
              value: '等额本金',
              name: '等额本金'
            },
          ],
          yearList: [],
          benxiObj: {}, // 本息
          benjinObj: {}, // 本金
        },
    
        /**
        * 生命周期函数--监听页面加载
        */
        onLoad(options: any) {
          if (wx.getStorageSync("token") || options?.token) {
            if (options?.token) {
              wx.setStorageSync("token", JSON.stringify(options.token));
            }
          this.getData()
          }
    
    
        },
        getData() {
          const newArray: any = []
          for (var i = 0; i < 30; i++) {
            const num = i + 1
            const list = {
              value: num,
              name: num + '年(' + 12 * num + ')月'
            }
            newArray.push(list)
          }
          this.setData({
            yearList: newArray
          })
        },
        onChangeName(e: any) {
          const { detail, currentTarget } = e;
          const { key } = currentTarget.dataset;
          this.setData({
            ...this.data.form,
            [key]: detail
          })
        },
        toPercent(point: any) {
          var str = Number(point / 100).toFixed(1);
          return str;
        },
        onSubmit() {
          const form: any = this.data.form;
          if (!form.total) {
            wx.showToast({
              title: "请输入贷款总额",
              icon: 'none'
            });
            return;
          } else if (!form.commercial) {
            wx.showToast({
              title: "请选择贷款年限",
              icon: 'none'
            });
            return;
          } else if (!form.rate) {
            wx.showToast({
              title: "请输入利率",
              icon: 'none'
            });
            return;
          }else if (form.loanType === 3 &&  !form.accumulationTotal) {
            wx.showToast({
              title: "请输入公积金贷款金额",
              icon: 'none'
            });
            return;
          }else if (form.loanType === 3 &&  !form.accumulationRate) {
            wx.showToast({
              title: "请输入公积金贷款利率",
              icon: 'none'
            });
            return;
          }else if (form.loanType === 3 &&  !form.accumulationYear) {
            wx.showToast({
              title: "请输入公积金贷款年限",
              icon: 'none'
            });
            return;
          }
          if (form.loanType === 1 || form.loanType === 2) {
            // 商业
            const benxiObj:any = this.benxi(form.total, form.commercial, form.rate);
            const newBenxiObj = {
              totalDknum: benxiObj.totalDknum,
              year: benxiObj.year,
              totalLixi: benxiObj.totalLixi.toFixed(2),
              totalPrice: benxiObj.totalPrice.toFixed(2),
              yuegong: benxiObj.yuegong.toFixed(2),
              monthdataArray: benxiObj.monthdataArray.length > 0 ? benxiObj.monthdataArray.map((el:any) => ({
                monthName: el.monthName,
                leftFund: el.leftFund.toFixed(2),
                yuebenjin: el.yuebenjin.toFixed(2),
                yuelixi: el.yuelixi.toFixed(2),
                yuegong: (el.yuebenjin +  el.yuelixi).toFixed(2),
              })) : []
            }
            const benjinObj:any = this.benjin(form.total, form.commercial, form.rate);
            const newBenjinObj = {
              totalDknum: benjinObj.totalDknum,
              year: benjinObj.year,
              totalLixi: benjinObj.totalLixi.toFixed(2),
              totalPrice: benjinObj.totalPrice.toFixed(2),
              yuegong: benjinObj.yuegong.toFixed(2),
              monthdataArray: benjinObj.monthdataArray.length > 0 ? benjinObj.monthdataArray.map((el:any) => ({
                monthName: el.monthName,
                leftFund: el.leftFund.toFixed(2),
                yuebenjin: el.yuebenjin.toFixed(2),
                yuelixi: el.yuelixi.toFixed(2),
                yuegong: (el.yuebenjin +  el.yuelixi).toFixed(2),
    
              })) : []
            }
            this.setData({
              benxiObj:newBenxiObj,
              benjinObj: newBenjinObj
            })
            if(form.loanType === 1) {
              wx.navigateTo({
                url: `/homeInfo/pages/calculationResults/index?benxiObj=${JSON.stringify(newBenxiObj)}&benjinObj=${JSON.stringify(newBenjinObj)}&sdlilv=${form.rate}&sdyear=${form.commercial}&sdnum=${form.total}&active=${form.repaymentName}`
              });
            }else {
              wx.navigateTo({
                url: `/homeInfo/pages/calculationResults/index?benxiObj=${JSON.stringify(newBenxiObj)}&benjinObj=${JSON.stringify(newBenjinObj)}&gjjlilv=${form.rate}&gjjyear=${form.commercial}&gjjnum=${form.total}&active=${form.repaymentName}`
              });
            }
    
    
          } else if (form.loanType === 3) {
            const benxiObj:any =  this.zuhe(1, form.total, form.accumulationTotal, form.commercial, form.accumulationYear, form.rate, form.accumulationRate);
            const newBenxiObj = {
              totalDknum: benxiObj.totalDknum,
              year: benxiObj.year,
              totalLixi: benxiObj.totalLixi.toFixed(2),
              totalPrice: benxiObj.totalPrice.toFixed(2),
              yuegong: benxiObj.yuegong.toFixed(2),
              monthdataArray: benxiObj.monthdataArray.length > 0 ? benxiObj.monthdataArray.map((el:any) => ({
                monthName: el.monthName,
                leftFund: el.leftFund.toFixed(2),
                yuebenjin: el.yuebenjin.toFixed(2),
                yuelixi: el.yuelixi.toFixed(2),
                yuegong: (el.yuebenjin +  el.yuelixi).toFixed(2),
    
              })) : []
            }
            const benjinObj:any = this.zuhe(2, form.total, form.accumulationTotal, form.commercial, form.accumulationYear, form.rate, form.accumulationRate);
            const newBenjinObj = {
              totalDknum: benjinObj.totalDknum,
              year: benjinObj.year,
              totalLixi: benjinObj.totalLixi.toFixed(2),
              totalPrice: benjinObj.totalPrice.toFixed(2),
              yuegong: benjinObj.yuegong.toFixed(2),
              monthdataArray: benjinObj.monthdataArray.length > 0 ? benjinObj.monthdataArray.map((el:any) => ({
                monthName: el.monthName,
                leftFund: el.leftFund.toFixed(2),
                yuebenjin: el.yuebenjin.toFixed(2),
                yuelixi: el.yuelixi.toFixed(2),
                yuegong: (el.yuebenjin +  el.yuelixi).toFixed(2),
    
              })) : []
            }
    
            this.setData({
              benxiObj: newBenxiObj,
              benjinObj: newBenjinObj
            })
            wx.navigateTo({
              url: `/homeInfo/pages/calculationResults/index?benxiObj=${JSON.stringify(newBenxiObj)}&benjinObj=${JSON.stringify(newBenjinObj)}&sdlilv=${form.rate}&sdyear=${form.commercial}&sdnum=${form.total}&gjjlilv=${form.accumulationRate}&gjjyear=${form.accumulationYear}&gjjnum=${form.accumulationTotal}&active=${form.repaymentName}`
            });
    
          }
        },
        /**
        * 组合贷款计算
        * @param type  还款方式
        * @param sdnum  商业贷款金额
        *  @param gjjnum 公积金贷款金额
        *  @param sdyear 商贷年限
        *  @param gjjyear 公积金年限
        *  @param sdlilv 贷款利率
        *  @param gjjlilv 公积金利率
        */
        zuhe(type: number, sdnum: number, gjjnum: number, sdyear: number, gjjyear: number, sdlilv: number, gjjlilv: number) {
          var _this = this,
            year = sdyear > gjjyear ? sdyear : gjjyear;
          if (type == 1) {
            var sdObj: any = _this.benxi(sdnum, sdyear, sdlilv);
            var gjjObj: any = _this.benxi(gjjnum, gjjyear, gjjlilv);
            if (sdObj.monthdataArray.length > gjjObj.monthdataArray.length) {
              var mergemonthdataArray = sdObj.monthdataArray.map((item: any, index: number) => {
                if (index < gjjObj.monthdataArray.length) {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi + gjjObj.monthdataArray[index].yuelixi,
                    yuebenjin: item.yuebenjin + gjjObj.monthdataArray[index].yuebenjin,
                    leftFund: item.leftFund + gjjObj.monthdataArray[index].leftFund,
                  };
                } else {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi,
                    yuebenjin: item.yuebenjin,
                    leftFund: item.leftFund,
                  };
                }
              });
            } else {
              var mergemonthdataArray = gjjObj.monthdataArray.map((item: any, index: number) => {
                if (index < sdObj.monthdataArray.length) {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi + sdObj.monthdataArray[index].yuelixi,
                    yuebenjin: item.yuebenjin + sdObj.monthdataArray[index].yuebenjin,
                    leftFund: item.leftFund + sdObj.monthdataArray[index].leftFund,
                  };
                } else {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi,
                    yuebenjin: item.yuebenjin,
                    leftFund: item.leftFund,
                  };
                }
              });
            }
            return {
              yuegong: sdObj.yuegong + gjjObj.yuegong,
              totalLixi: sdObj.totalLixi + gjjObj.totalLixi,
              totalPrice: sdObj.totalPrice + gjjObj.totalPrice,
              monthdataArray: mergemonthdataArray,
              totalDknum: parseFloat(sdObj.totalDknum) + parseFloat(gjjObj.totalDknum),
              year: year,
            };
          } else if (type == 2) {
            var sdObj: any = _this.benjin(sdnum, sdyear, sdlilv);
            var gjjObj: any = _this.benjin(gjjnum, gjjyear, gjjlilv);
            if (sdObj.monthdataArray.length > gjjObj.monthdataArray.length) {
              var mergemonthdataArray = sdObj.monthdataArray.map((item: any, index: number) => {
                if (index < gjjObj.monthdataArray.length) {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi + gjjObj.monthdataArray[index].yuelixi,
                    yuebenjin: item.yuebenjin + gjjObj.monthdataArray[index].yuebenjin,
                    leftFund: item.leftFund + gjjObj.monthdataArray[index].leftFund,
                  };
                } else {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi,
                    yuebenjin: item.yuebenjin,
                    leftFund: item.leftFund,
                  };
                }
              });
            } else {
              var mergemonthdataArray = gjjObj.monthdataArray.map((item: any, index: number) => {
                if (index < sdObj.monthdataArray.length) {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi + sdObj.monthdataArray[index].yuelixi,
                    yuebenjin: item.yuebenjin + sdObj.monthdataArray[index].yuebenjin,
                    leftFund: item.leftFund + sdObj.monthdataArray[index].leftFund,
                  };
                } else {
                  return {
                    monthName: item.monthName,
                    yuelixi: item.yuelixi,
                    yuebenjin: item.yuebenjin,
                    leftFund: item.leftFund,
                  };
                }
              });
            }
            return {
              yuegong: sdObj.yuegong + gjjObj.yuegong,
              totalLixi: sdObj.totalLixi + gjjObj.totalLixi,
              totalPrice: sdObj.totalPrice + gjjObj.totalPrice,
              yuegongdijian: sdObj.yuegongdijian + gjjObj.yuegongdijian,
              totalDknum: parseFloat(sdObj.totalDknum) + parseFloat(gjjObj.totalDknum),
              year: year,
              monthdataArray: mergemonthdataArray,
            };
          }
    
    
    
        },
        // 房贷分两种支付方式:等额本息和等额本金,具体公式如下:等额本息:〔贷款本金×月利率×(1+月利率)^还款月数〕÷〔(1+月利率)^还款月数-1〕等额本金:每月还款金额 = (贷款本金 / 还款月数)+(本金 — 已归还本金累计额)×每月利率其中^符号表示乘方。2个月就是2次方。
        //等额本息计算
        benxi(num: any, year: any, lilv: any) {
          //每月月供额=〔贷款本金×月利率×(1+月利率)^还款月数〕÷〔(1+月利率)^还款月数-1〕
          var lilvnum: any = Number(Number(lilv / 100).toLocaleString(undefined));
          var mouth = parseInt(year) * 12,
            mouthlilv = parseFloat(lilvnum) / 12,
            dknum = parseFloat(num) * 10000;
          //每月月供
          var yuegong = (dknum * mouthlilv * Math.pow((1 + mouthlilv), mouth)) / (Math.pow((1 + mouthlilv), mouth) - 1);
          //总利息=还款月数×每月月供额-贷款本金
          var totalLixi = mouth * yuegong - dknum;
          //还款总额 总利息+贷款本金
          var totalPrice = totalLixi + dknum,
            leftFund = totalLixi + dknum;
    
          //循环月份
          var monthdataArray = [],
            nowmouth = new Date().getMonth(),
            realmonth = 0;
    
          for (var i = 1; i <= mouth; i++) {
            realmonth = nowmouth + i;
            var yearlist = Math.floor(i / 12);
    
            realmonth = realmonth - 12 * yearlist;
    
            if (realmonth > 12) {
              realmonth = realmonth - 12
            }
            //console.log(realmonth)
            //每月应还利息=贷款本金×月利率×〔(1+月利率)^还款月数-(1+月利率)^(还款月序号-1)〕÷〔(1+月利率)^还款月数-1〕
            var yuelixi = dknum * mouthlilv * (Math.pow((1 + mouthlilv), mouth) - Math.pow((1 + mouthlilv), i - 1)) / (Math.pow((1 + mouthlilv), mouth) - 1);
            //每月应还本金=贷款本金×月利率×(1+月利率)^(还款月序号-1)÷〔(1+月利率)^还款月数-1〕
            var yuebenjin = dknum * mouthlilv * Math.pow((1 + mouthlilv), i - 1) / (Math.pow((1 + mouthlilv), mouth) - 1);
            leftFund = leftFund - (yuelixi + yuebenjin);
            if (leftFund < 0) {
              leftFund = 0
            }
            monthdataArray[i - 1] = {
              monthName: realmonth + "月",
              yuelixi: yuelixi,
              yuebenjin: yuebenjin,
              //剩余还款
              leftFund: leftFund
            }
          }
          return {
            yuegong: yuegong,
            totalLixi: totalLixi,
            totalPrice: totalPrice,
            monthdataArray: monthdataArray,
            totalDknum: num,
            year: year
          };
        },
        //等额本金计算
        benjin(num: any, year: any, lilv: any) {
          var lilvnum: any = Number(Number(lilv / 100).toLocaleString(undefined));
          var mouth = parseInt(year) * 12,
            mouthlilv = parseFloat(lilvnum) / 12,
            dknum = parseFloat(num) * 10000,
            yhbenjin = 0; //首月还款已还本金金额是0
          //每月应还本金=贷款本金÷还款月数
          var everymonthyh = dknum / mouth
          //每月月供额=(贷款本金÷还款月数)+(贷款本金-已归还本金累计额)×月利率
          var yuegong = everymonthyh + (dknum - yhbenjin) * mouthlilv;
          //每月月供递减额=每月应还本金×月利率=贷款本金÷还款月数×月利率
          var yuegongdijian = everymonthyh * mouthlilv;
          //总利息=〔(总贷款额÷还款月数+总贷款额×月利率)+总贷款额÷还款月数×(1+月利率)〕÷2×还款月数-总贷款额
          var totalLixi = ((everymonthyh + dknum * mouthlilv) + dknum / mouth * (1 + mouthlilv)) / 2 * mouth - dknum;
          //还款总额 总利息+贷款本金
          var totalPrice = totalLixi + dknum,
            leftFund = totalLixi + dknum;
    
          //循环月份
          var monthdataArray = [],
            nowmouth = new Date().getMonth(),
            realmonth = 0;
    
          for (var i = 1; i <= mouth; i++) {
            realmonth = nowmouth + i;
            var yearlist = Math.floor(i / 12);
    
            realmonth = realmonth - 12 * yearlist;
    
            if (realmonth > 12) {
              realmonth = realmonth - 12
            }
            yhbenjin = everymonthyh * (i - 1);
            var yuebenjin = everymonthyh + (dknum - yhbenjin) * mouthlilv;
            //每月应还利息=剩余本金×月利率=(贷款本金-已归还本金累计额)×月利率
            var yuelixi = (dknum - yhbenjin) * mouthlilv;
            leftFund = leftFund - yuebenjin;
            if (leftFund < 0) {
              leftFund = 0
            }
            monthdataArray[i - 1] = {
              monthName: realmonth + "月",
              // yuelixi: yuelixi.toFixed(2),
              // //每月本金
              // yuebenjin: everymonthyh.toFixed(2),
              // //剩余还款
              // leftFund: leftFund.toFixed(2)
              yuelixi: yuelixi,
              //每月本金
              yuebenjin: everymonthyh,
              //剩余还款
              leftFund: leftFund
            }
          }
          return {
            // yuegong: yuegong.toFixed(2),
            // totalLixi: totalLixi.toFixed(2),
            // totalPrice: totalPrice.toFixed(2),
            // yuegongdijian: yuegongdijian.toFixed(2),
            yuegong: yuegong,
            totalLixi: totalLixi,
            totalPrice: totalPrice,
            yuegongdijian: yuegongdijian,
            monthdataArray: monthdataArray,
            totalDknum: num,
            year: year
          }
    
        },
                /**
      * 用户点击右上角分享
      */
      onShareAppMessage: function () {
        return {
          path: `/homeInfo/pages/mortgage/index`,
        }
      },
      onShareTimeline: function () {
        return {
          query: `/homeInfo/pages/mortgage/index?test=1&token=${wx.getStorageSync("token")}`,
        }
      }
    
    
      })
    
  • index.scss

      .mortgage-page {
        .van-cell  {
          padding:  13px;
          font-size: 16px;
          margin-top: 5px;
        }
        .van-field__label ,.van-field__control {
          color: #333 !important;
        }
        .mortgage-btn {
          padding: 24px 13px 24px 12px;
        }
      }
    
  • index.json

      {
        "navigationBarTitleText": "房贷计算",
        "usingComponents": {
          "van-field": "@vant/weapp/field/index",
          "van-cell-group": "@vant/weapp/cell-group/index",
          "van-button": "@vant/weapp/button/index",
          "HChosen": "/components/h-chosen/index"
        }
      }
    

计算结果

  • calculationResults/index

  • index.wxml

      <view class="calculationResults">
        <van-tabs active="{{ active }}" bind:change="onChange" color="#e90820" title-inactive-color="#666" title-active-color="#e90820">
          <van-tab title="等额本息" name="等额本息">
            <view class="calculationResults-top  box-b red-bg white-color  ">
              <van-row>
                <van-col span="24">
                  <view class="f14">
                    贷款总额(万元)
                  </view>
                  <view class="f25 fmedium calculation-total ">
                    {{benxiObj.totalDknum}}
                  </view>
                </van-col>
                <van-col span="12">
                  <view class="f14">
                    利息总额(万元)
                  </view>
                  <view class="f14">
                    {{benxiObj.totalLixi}}
                  </view>
                </van-col>
                <van-col span="12">
                  <view class="f14">
                    还款总额(万元)
                  </view>
                  <view class="f14">
                    {{benxiObj.totalPrice}}
                  </view>
                </van-col>
              </van-row>
            </view>
    
    
          </van-tab>
          <van-tab title="等额本金" name="等额本金">
            <view class="calculationResults-top box-b red-bg white-color  ">
              <van-row>
                <van-col span="24">
                  <view class="f14">
                    贷款总额(万元)
                  </view>
                  <view class="f25 fmedium calculation-total ">
                    {{benjinObj.totalDknum}}
                  </view>
                </van-col>
                <van-col span="12">
                  <view class="f14">
                    利息总额(万元)
                  </view>
                  <view class="f14">
                    {{benjinObj.totalLixi}}
                  </view>
                </van-col>
                <van-col span="12">
                  <view class="f14">
                    还款总额(万元)
                  </view>
                  <view class="f14">
                    {{benjinObj.totalPrice}}
                  </view>
                </van-col>
              </van-row>
            </view>
          </van-tab>
        </van-tabs>
    
        <view class="calculationResults-top white-bg"  wx:if="{{sdnum}}">
          <van-row>
            <van-col span="24">
              <view class="calculation-type">
                商业贷款
              </view>
            </van-col>
            <van-col span="24">
              <view class="f14">
                每月还款(元)
              </view>
              <view class="f25 fmedium calculation-total ">
                {{ active === '等额本息' ? benxiObj.yuegong : benjinObj.yuegong }}
              </view>
            </van-col>
            <van-col span="8">
              <view class="f14">
                贷款金额(万元)
              </view>
              <view class="f14">
                {{sdnum}}
              </view>
            </van-col>
            <van-col span="8">
              <view class="f14">
                利率(%)
              </view>
              <view class="f14">
                {{sdlilv}}
              </view>
            </van-col>
            <van-col span="8">
              <view class="f14">
                贷款年限(年)
              </view>
              <view class="f14">
                {{sdyear}}
              </view>
            </van-col>
          </van-row>
        </view>
    
        <view class="calculationResults-top white-bg" wx:if="{{gjjnum}}">
          <van-row >
            <van-col span="24">
              <view class="calculation-type">
                公积金贷款
              </view>
            </van-col>
            <van-col span="24">
              <view class="f14">
                每月还款(元)
              </view>
              <view class="f25 fmedium calculation-total ">
                {{benxiObj.yuegong}}
              </view>
            </van-col>
            <van-col span="8">
              <view class="f14">
                贷款金额(万元)
              </view>
              <view class="f14">
                {{gjjnum}}
              </view>
            </van-col>
            <van-col span="8">
              <view class="f14">
                利率(%)
              </view>
              <view class="f14">
                {{gjjlilv}}
              </view>
            </van-col>
            <van-col span="8">
              <view class="f14">
                贷款年限(年)
              </view>
              <view class="f14">
                {{gjjyear}}
              </view>
            </van-col>
          </van-row>
        </view>
    
        <view class="f14 color-999  title box-b">
          以上结果仅供参考,请以当地实际情况为主
        </view>
        <view class="calculationResults-btn box-b">
          <van-button size="large" color="#a31f23" block bind:click="onDetail">查看月供详情</van-button>
        </view>
    
      </view>
    
  • index.ts

      Page({
    
        /**
        * 页面的初始数据
        */
        data: {
          sdyear: '',
          sdnum: '',
          sdlilv: '',
          gjjyear: '',
          gjjlilv: '',
          gjjnum: '',
          benxiObj: {},
          benjinObj: {},
          active: '等额本息'
        },
    
        /**
        * 生命周期函数--监听页面加载
        */
        onLoad(options:any) {
          if(options.sdlilv || options.gjjlilv) {
            this.setData({
              sdlilv: options.sdlilv,
              sdnum: options.sdnum,
              sdyear: options.sdyear,
              gjjyear: options.gjjyear,
              gjjlilv: options.gjjlilv,
              gjjnum: options.gjjnum,
              active: options.active ? options.active : this.data.active,
              benxiObj: JSON.parse(options.benxiObj),
              benjinObj: JSON.parse(options.benjinObj),
            })
          }
    
        },
    
    
        /**
        * 生命周期函数--监听页面显示
        */
        onShow() {
    
        },
        onChange(e:any) {
          this.setData({
            active: e.detail.name
          })
    
        },
        onDetail() {
          const tmp:any = this.data;
          const monthdataArray = this.data.active === '等额本息' ? tmp.benxiObj.monthdataArray :  tmp.benjinObj.monthdataArray;
          wx.navigateTo({
            url: `/homeInfo/pages/monthlySupply/index?monthdataArray=${JSON.stringify(monthdataArray)}`
          });
    
    
        },
    
        /**
        * 生命周期函数--监听页面隐藏
        */
        onHide() {
    
        },
    
        /**
        * 生命周期函数--监听页面卸载
        */
        onUnload() {
    
        },
    
        /**
        * 页面相关事件处理函数--监听用户下拉动作
        */
        onPullDownRefresh() {
    
        },
    
        /**
        * 页面上拉触底事件的处理函数
        */
        onReachBottom() {
    
        },
      })
    
  • index.scss

      .calculationResults {
    
        .calculationResults-top {
          padding: 10px;
          margin-top: 5px;
          &.calculationResults-top {
            margin-bottom: 15px;
    
          }
          .calculation-type {
            margin-bottom: 5px;
          }
          view {
            line-height: 22px;
          }
          .calculation-total {
            margin-bottom: 10px;
          }
          .gjj-box {
            margin-top: 15px;
          }
    
        }
        .title {
          padding-left: 10px;
        }
        .calculationResults-btn {
          padding: 24px 13px 24px 12px;
        }
    
      }
    
  • index.json

      {
        "navigationBarTitleText": "计算结果",
        "usingComponents": {
          "van-tab": "@vant/weapp/tab/index",
          "van-tabs": "@vant/weapp/tabs/index",
          "van-button": "@vant/weapp/button/index",
          "van-row": "@vant/weapp/row/index",
          "van-col": "@vant/weapp/col/index"
        }
      }
    

月供详情

  • monthlySupply/index

  • index.wxml

      <scroll-view class="table"  scroll-y >
        <view class="sticky-box" >
          <view class="table__head" >
            <view class="table__head__td" wx:for="{{dataAttribute}}" wx:key="attrIndex" wx:for-index="attrIndex" wx:for-item="attrItem">
              <text
                class="table__head__td__text"
              >{{attrItem.title}}</text>
            </view>
          </view>
          <view class="table__row" wx:for="{{monthdataArray}}" wx:key="dataIndex" >
            <text class="table__row__td" >{{item.monthName}}</text>
            <text class="table__row__td" >{{item.yuegong}}</text>
            <text class="table__row__td" >{{item.yuebenjin}}</text>
            <text class="table__row__td" >{{item.yuelixi}}</text>
            <text class="table__row__td" >{{item.leftFund}}</text>
          </view>
        </view>
      </scroll-view>
    
  • index.ts

      Page({
    
      /**
      * 页面的初始数据
      */
      data: {
        monthdataArray: [],
    
        dataAttribute: [
          {
            title: '月份',
          },
          {
            title: '月供(元)',
          },
          {
            title: '本金(元)',
          },
          {
            title: '利息(元)',
          },
          {
            title: '剩余贷款(元)',
          },
    
        ],
        // tableHeight: (20 + 1) * 96,
        // tableWidth: 200 * 6 + 60
    
    
      },
    
      /**
      * 生命周期函数--监听页面加载
      */
      onLoad(options:any) {
        if(options.monthdataArray) {
          this.setData({
            monthdataArray: JSON.parse(options.monthdataArray)
          })
        }
      },
    
      /**
      * 生命周期函数--监听页面初次渲染完成
      */
      onReady() {
    
      },
    
      /**
      * 生命周期函数--监听页面显示
      */
      onShow() {
    
      },
    
      /**
      * 生命周期函数--监听页面隐藏
      */
      onHide() {
    
      },
    
      /**
      * 生命周期函数--监听页面卸载
      */
      onUnload() {
    
      },
    
      /**
      * 页面相关事件处理函数--监听用户下拉动作
      */
      onPullDownRefresh() {
    
      },
    
      /**
      * 页面上拉触底事件的处理函数
      */
      onReachBottom() {
    
      },
    
      /**
      * 用户点击右上角分享
      */
      onShareAppMessage() {
    
      }
    })
    
  • index.scss

      .table{
        display: block;
        position: relative;
        overflow: scroll;
        width: 100%;
        height: 100%;
    
      .table__head{
        height: 96rpx;
        white-space: nowrap;
        position: sticky;
        top: 0rpx;
        z-index: 100;
        height: 88rpx;
        font-size: 24rpx;
        line-height: 88rpx;
        color: #aaabbd;
        background-color: #f8f8f8;
        border-bottom: 2rpx solid #ecf1f8;
        background-color: #fff;
        white-space: nowrap;
        display: flex;
      }
      .table__head__td{
        width: 25%;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        background-color: #fff;
        box-sizing: border-box;
        position: relative;
        overflow: hidden;
        white-space: nowrap;
        -o-text-overflow: ellipsis;
        text-overflow: ellipsis;
        &:first-child {
          padding-left: 10px;
          box-sizing: border-box;
        }
      }
    
      .table__head__td__text{
        display: inline;
      }
      .table__row{
        position: relative;
        height: 96rpx;
        white-space: nowrap;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        border-bottom: 2rpx solid #ecf1f8;
      }
      .table__row__td{
        white-space: nowrap;
        width: 25%;
        display: inline-block;
        background-color: #fff;
        box-sizing: border-box;
        font-size: 26rpx;
        line-height: 96rpx;
        position: relative;
        overflow: hidden;
        white-space: nowrap;
        -o-text-overflow: ellipsis;
        text-overflow: ellipsis;
        &:first-child {
          padding-left: 10px;
          box-sizing: border-box;
        }
      }
      }
    
  • index.json

      {
        "navigationBarTitleText": "月供详情",
        "usingComponents": {}
      }
    
posted @ 2024-04-17 10:39  不完美的完美  阅读(126)  评论(0编辑  收藏  举报