ホームページ >ウェブフロントエンド >jsチュートリアル >Vue を使用して数字キーボード コンポーネントをカスタマイズする方法

Vue を使用して数字キーボード コンポーネントをカスタマイズする方法

不言
不言オリジナル
2018-06-30 17:39:492022ブラウズ

この記事では主に Vue を使用して数値キーボード コンポーネントをカスタマイズする方法を紹介します。金額の入力に関しては、ネイティブ入力を使用するのはエクスペリエンスが良くないので、具体的な実装コードについては、この記事を参照してください。ユーザーエクスペリエンスを満たすために、エディターでは、優れたユーザーエクスペリエンスを備えた Vue を使用してカスタム数値キーボードコンポーネントを作成しました。

早速、レンダリングから始めましょう~

レンダリング

詳細な実装

レイアウトと組版

<p class=&#39;key-container&#39;>
  <p class=&#39;key-title&#39;>请输入金额</p>
  <p class=&#39;input-box&#39;>{{ money }}</p>
  <p class=&#39;keyboard&#39; @click.stop=&#39;_handleKeyPress&#39;>
    <p class=&#39;key-row&#39;>
      <p class=&#39;key-cell&#39; data-num=&#39;7&#39;>7</p>
      <p class=&#39;key-cell&#39; data-num=&#39;8&#39;>8</p>
      <p class=&#39;key-cell&#39; data-num=&#39;9&#39;>9</p>
      <p class=&#39;key-cell&#39; data-num=&#39;D&#39;>C</p>
    </p>
    <p class=&#39;key-row&#39;>
      <p class=&#39;key-cell&#39; data-num=&#39;4&#39;>4</p>
      <p class=&#39;key-cell&#39; data-num=&#39;5&#39;>5</p>
      <p class=&#39;key-cell&#39; data-num=&#39;6&#39;>6</p>
      <p class=&#39;key-cell&#39; data-num=&#39;C&#39;>清空</p>
    </p>
    <p class=&#39;key-row&#39;>
      <p class=&#39;key-cell&#39; data-num=&#39;1&#39;>1</p>
      <p class=&#39;key-cell&#39; data-num=&#39;2&#39;>2</p>
      <p class=&#39;key-cell&#39; data-num=&#39;3&#39;>3</p>
      <p class=&#39;key-cell&#39; data-num=&#39;-1&#39;></p>
    </p>
    <p class=&#39;key-row&#39;>
      <p class=&#39;key-cell disabled&#39; data-num=&#39;-1&#39;></p>
      <p class=&#39;key-cell&#39; data-num=&#39;.&#39;>.</p>
      <p class=&#39;key-cell&#39; data-num=&#39;0&#39;>0</p>
      <p class=&#39;key-cell&#39; data-num=&#39;-1&#39;></p>
    </p>
    <p class=&#39;key-confirm&#39; data-num=&#39;S&#39;>确认</p>
  </p>
</p>
レイアウトに関して, I すべては p 要素を使用してシミュレートされており、便利で使いやすいです (๑ŐдŐ)b キーボードのキーに関しては、各ボタンにはカスタム属性値 num が設定されており、その目的は、押すことによって生成されるさまざまな効果を区別することです。キー

イベントはキャプチャを通じて特定のクリックされた要素を決定するために使用されます。ここではスタイルコードを投稿しません。具体的な詳細はgithubでホストします~

。キーボードにとって最も重要なことは入力判定です。キーボードの入力全体は最初に _handleKeyPress によって処理されます

//处理按键
_handleKeyPress(e) {
 let num = e.target.dataset.num;
 //不同按键处理逻辑
 // -1 代表无效按键,直接返回
 if (num == -1) return false;
 switch (String(num)) {
 //小数点
 case &#39;.&#39;:
  this._handleDecimalPoint();
  break;
 //删除键
 case &#39;D&#39;:
  this._handleDeleteKey();
  break;
 //清空键
 case &#39;C&#39;:
  this._handleClearKey();
  break;
 //确认键
 case &#39;S&#39;:
  this._handleConfirmKey();
  break;
 default:
  this._handleNumberKey(num);
  break;
 }
}

ご覧のとおり、キーの種類を小数点、削除 (バックスペース) キー、クリアの 5 つのカテゴリに分けました。キーと数字キーはそれぞれ別の処理機能を使っていますので、一つ一つ分析してみましょう

小数点は最大1つしか入力できないので、ある場合は判定する必要があります。小数点は直接返されます。そうでない場合は、小数点が最初に入力された文字です。そうでない場合は、小数点を現在の文字の末尾に追加します。

//处理小数点函数
 _handleDecimalPoint() {
  //如果包含小数点,直接返回
  if (this.money.indexOf(&#39;.&#39;) > -1) return false;
  //如果小数点是第一位,补0
  if (!this.money.length)
  this.money = &#39;0.&#39;;
  //如果不是,添加一个小数点
  else
  this.money = this.money + &#39;.&#39;;
 }
削除 (バックスペース) キー、処理がより便利です。まず現在の入力が空であるかどうかを判断し、文字がない場合は直接戻り、文字列の最後の文字を削除します。
//处理删除键
 _handleDeleteKey() {
  let S = this.money;
  //如果没有输入,直接返回
  if (!S.length) return false;
  //否则删除最后一个
  this.money = S.substring(0, S.length - 1);
 }
クリア キー、ロジックは最も単純で、現在の文字をクリアするだけです。
//处理清空键
 _handleClearKey() {
  this.money = &#39;&#39;;
 }

キーを確認し、現在の文字が空であるかどうかを確認します。空でない場合は、メッセージが表示され、返されます。入力は 8 です。この形式では、8.00 の形式に整列してフォーマットする必要があります。そうでない場合は、小数点以下 2 桁を直接保持し、最後にコールバックをトリガーして結果をパラメーターとして渡します。数字キーの操作はそれほど複雑ではありません。小数点があるかどうかを確認し、小数点がある場合は 2 桁まで入力します。小数点がない場合は、最初の桁を判断する必要があります。入力桁は 0 ですか? 0 の場合は小数点のみを入力でき、0000 などの無効な入力も避ける必要があるため、追加の判定を追加しました。それ以外の場合は、現在の文字の直後に追加します。
_handleConfirmKey() {
  let S = this.money;
  //未输入
  if (!S.length){
  alert( &#39;您目前未输入!&#39; )
  return false;
  }
  //将 8. 这种转换成 8.00
  if (S.indexOf(&#39;.&#39;) > -1 && S.indexOf(&#39;.&#39;) == (S.length - 1))
  S = Number(S.substring(0, S.length - 1)).toFixed(2);
  //保留两位
  S = Number(S).toFixed(2);
  this.$emit(&#39;confirmEvent&#39;,S)
 }

コンポーネントの紹介

コンポーネントの準備ができました。パスを入力し、対応するコンポーネントに登録し、使用するページに直接配置します。次のようになります

//处理数字
 _handleNumberKey(num) {
  let S = this.money;
  //如果有小数点且小数点位数不小于2
  if ( S.indexOf(&#39;.&#39;) > -1 && S.substring(S.indexOf(&#39;.&#39;) + 1).length < 2)
  this.money = S + num;
  //没有小数点
  if (!(S.indexOf(&#39;.&#39;) > -1)) {
  //如果第一位是0,只能输入小数点
  if (num == 0 && S.length == 0)
   this.money = &#39;0.&#39;;
  else {
   if (S.length && Number(S.charAt(0)) === 0) return;
   this.money = S + num;
  }
  }
 }

。ここで、_confirmEvent はクリックしたときです確認ボタンのコールバック、パラメータは入力された量です。ここに印刷します~

<calculation @confirmEvent="_confirmEvent"></calculation>

効果は以下とほぼ同じです

上記がこの記事の全内容です。その他の関連コンテンツについては、PHP 中国語 Web サイトに注目してください。 関連する推奨事項:

VueJS コンポーネントが props を介して対話および検証する方法

Vue コンポーネントの通信実践の紹介

以上がVue を使用して数字キーボード コンポーネントをカスタマイズする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。