目次
アップデート!バニラJavaScriptを使用した新しいバージョンもあります。
他のバージョン
?この投稿のオリジナルバージョンの古いバージョン(jQuery、さらには機能しません)

範囲入力の値バブル

Apr 08, 2025 am 10:31 AM

範囲入力の値バブル

HTMLの範囲入力は次のようなものです。

 
ログイン後にコピー

それらをサポートするブラウザでは、彼らは次のように見えます:

今ではそれが素晴らしいです。最小値と最大値が強制されているユーザーから番号を収集したい場合は、それを使用できます。

しかし、奇妙なことに気づきますか?それ自体では、その範囲の入力は、実際に提出する番号がユーザーに通信しません。今、あなたの入力が「お元気ですか? - それでは、おそらくユーザーに番号を表示する必要はありません。しかし、私はあなたがそれを見せないよりもあなたが数を表示する必要があることをより一般的に賭けます。

公平を期すために、仕様は次のように述べています。

入力要素は、要素の値を数値を表す文字列に設定するためのコントロールを表しますが、正確な値は重要ではないという警告があり、UASは数値状態よりも単純なインターフェイスを提供します。

しかし、クールなスライダーが必要なからといって、自動的にユーザーが提出された値を知ることを防ぐ必要があるという意味ではありません。ブラウザがUIコントロールを変更してその数を表示する必要があるとは限りません。私たちはそれを自分で構築するべきだと言っています!

これは、フォーム要素によって計算された値に特化したタグの完璧なユースケースです。これがあなたがそれをどのように使用するかについての非常にシンプルな実装です:

 
<output for="foo" onforminput="value = foo.valueasnumber;"> </output>
ログイン後にコピー

アップデート!バニラJavaScriptを使用した新しいバージョンもあります。

ここでの目標は、範囲入力の現在の値を示す「バブル」を表示することです。

入力の値から「バブル」の値を設定することは、範囲の値を引いてバブルに陥る問題です。

 range.addeventlistener( "input"、()=> {
  bubble.innerhtml = rangel.value;
});
ログイン後にコピー

トリックは、バブルを範囲入力に沿って配置することで、「親指」に沿ってスライドします。そのためには、バブルを左にスクーティングする必要がある%を計算する必要があります。それで、物事をスミッジクリーナーに保つためにそれを行うための機能を作りましょう:

 range.addeventlistener( "input"、()=> {
  SetBubble(範囲、バブル);
});

関数setBubble(範囲、バブル){
  const val = range.value;
  const min = range.min? range.min:0;
  const max = range.max? range.max:100;
  const newval = number(((val -min) * 100) /(max -min));
  bubble.innerhtml = val;

  //ネイティブUIの親指のサイズに基づいて魔法の数字を並べ替える
  bubble.style.left = newval = "%";
}
ログイン後にコピー

ここでは、範囲入力minとmax属性を説明し、その範囲の現在の値に基づいて0〜100の間のポジションを計算することを確認します。すべての範囲がデフォルトの0〜100の数値であるわけではないため、範囲が0〜200の範囲で値50であったと言いますが、それは25%です。これはそれを説明します。

しかし、それには1つの迷惑な欠陥があります。バブルは、スタートの左に遠すぎ、最後の右側まで遠すぎます。範囲の入力では、親指が左端から垂れ下がらないため、中央が最初にあり、最後に同じです。スクロールバーのように、親指の端がトラック内に止まります。

ブラウザ全体できちんと機能するように見えるいくつかの魔法の数字を使用できます。

 //ネイティブUIの親指のサイズに基づいて魔法の数字を並べ替える
  bubble.style.left = `calc($ {newval}%($ {8 -newval * 0.15} px))`;
ログイン後にコピー

これがその最終的なデモです:

読者のMaxglobaが彼らのバージョンに書いたので、私はこれを突くように促されました:ここに投稿します:

Maxのバージョンのクールな側面は、範囲入力がCSSスタイルであるため、親指の正確なサイズがわかっていることです。 JavaScript数学にはむしろ魔法を感じる数字がいくつかありますが、少なくともそれらは親指のサイズについてCSSに設定された実数に基づいています。

他のバージョン

デイブ・オルセンは、jQueryに依存しないように(元の)アイデアを移植しました。これがそのバージョンです:

ショーン・ストップニク:

Simurai:

ヴィンセント・デュランド:

範囲の入力には、ちょっとクールなノッチをほとんど入れないデータリストがあります。

Ana Tudorには大規模なコレクションがあり、その多くはデザインを通じて現在の値を示しています。

?この投稿のオリジナルバージョンの古いバージョン(jQuery、さらには機能しません)

歴史的な理由でこれをここに残してください。

友人のjqueryを引き込み、CSSをつけましょう。この目標は以下です。任意の範囲入力、いつでも、任意のmin/max/step - 現在の値を示すバブルを上に置きます。

最初に出力要素をスタイルしましょう。絶対に入力の上に配置します。これにより、JavaScriptがどうあるべきかを把握したら、左値も調整することができます。グラデーションとボーダーラジウスでそれを空想し、擬似エレメントで小さなポインタートライアングルを追加します。

出力{ 
  位置:絶対;
  背景画像:線形勾配(TOP、#444444、#999999);
  幅:40px; 
  高さ:30px; 
  テキストアライグ:センター; 
  色:白; 
  ボーダーラジウス:10px; 
  ディスプレイ:インラインブロック。 
  フォント:Bold 15px/30px Georgia;
  下:175%;
  左:0;
  マージン左:-1%;
}
出力:後{ 
  コンテンツ: "";
  位置:絶対;
  幅:0;
  高さ:0;
  ボーダートップ:10pxソリッド#999999;
  国境左:5px固体透明。
  国境右:5px固体透明。
  トップ:100%;
  左:50%;
  マージン左:-5px;
  マージントップ:-1px;
}
ログイン後にコピー

ここで、私たちがする必要があるのは、すべての範囲入力を監視して、その価値を変えることです。私たちの目標は、バブルの左の位置をスライダーとペースでシフトすることです。それは世界で最も単純なものではありません。スライダーは、任意の幅であり、最小値または最大値であることです。少し数学をしなければなりません。これがすべてのjquery javascriptです。

 // DOM READY
$(function(){
 Var El、NewPoint、Newplace、Offset;
 
 //すべての範囲の入力を選択し、変更に注意してください
 $( "input [type = 'range']")。change(function(){{
 
   //効率のためにこれをキャッシュします
   el = $(this);
   
   //範囲入力の幅を測定します
   width = el.width();
   
   //入力の左右の間の配置率を把握する
   newpoint =(el.val() -  el.attr( "min")) /(el.attr( "max") -  el.attr( "min"));
   
   //ポインターをより良く並べるためのJanky値
   オフセット= -1.3;
   
   //バブルが左または右を越えて行くのを防ぐ(サポートされていないブラウザ)
   if(newpoint  1){newplace = width; }
   else {newplace = width * newpoint offset;オフセット -  = newpoint; }
   
   //バブルを移動します
   エル
     .next( "output")
     .css({
       左:新しい場所、
       マージン左:オフセット「%」
     })
     .text(el.val());
 })
 //ページロードでの位置バブルへの変更を偽造
 .trigger( 'change');
});
ログイン後にコピー

そこにある1つのグロス部分は、その1.3値です。バブルの三角形の先端をスライダーの中心に並べようとしていました。スライダーの中心が左または右に100%または右にないため、簡単ではありません。その価値は完全ではなく、完全に実装されていませんが、それを持っていないよりはましです。

ボーナスとして、範囲入力をサポートしないブラウザはバブルアクションを取得します。

上記のコードは、指定されたMINと最大値を持つ範囲入力に依存します。そうでなければ、それはちょっと壊れます。これらのことを指定せずに範囲の入力を使用するのは奇妙だと思いますが、そうでない場合はデフォルトと100と思われます。これを防ぐために、各属性をつかんでテストし、正しく修正していない場合はテストします。次のようなもの:

 var minvalue、maxvalue;
if(!el.attr( "min")){minvalue = 0; } else {minvalue = el.attr( "min"); }
ログイン後にコピー

…次に、数学でminvalue変数を使用します。そして、最大で同様のことをします。とにかく、これがライブデモです:

以上が範囲入力の値バブルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

粘着性のあるポジショニングとサスのダッシュを備えた積み重ねられたカード 粘着性のあるポジショニングとサスのダッシュを備えた積み重ねられたカード Apr 03, 2025 am 10:30 AM

先日、Corey Ginnivanのウェブサイトから、この特に素敵なビットを見つけました。そこでは、スクロール中にカードのコレクションが互いに積み重ねられていました。

Googleフォント変数フォント Googleフォント変数フォント Apr 09, 2025 am 10:42 AM

Google Fontsが新しいデザイン(ツイート)を展開したようです。最後の大きな再設計と比較して、これははるかに反復的です。違いをほとんど伝えることができません

HTML、CSS、JavaScriptを使用してアニメーションカウントダウンタイマーを作成する方法 HTML、CSS、JavaScriptを使用してアニメーションカウントダウンタイマーを作成する方法 Apr 11, 2025 am 11:29 AM

プロジェクトにカウントダウンタイマーが必要だったことはありますか?そのようなことのために、プラグインに手を伸ばすのは自然なことかもしれませんが、実際にはもっとたくさんあります

HTMLデータ属性ガイド HTMLデータ属性ガイド Apr 11, 2025 am 11:50 AM

HTML、CSS、およびJavaScriptのデータ属性について知りたいと思っていたことはすべて。

CSSを介してファーストクラスの名前アイテムを使用して子要素を選択する方法は? CSSを介してファーストクラスの名前アイテムを使用して子要素を選択する方法は? Apr 05, 2025 pm 11:24 PM

要素の数が固定されていない場合、CSSを介して指定されたクラス名の最初の子要素を選択する方法。 HTML構造を処理するとき、あなたはしばしば異なる要素に遭遇します...

フレックスレイアウト内の紫色のスラッシュ領域が誤って「オーバーフロー空間」と見なされるのはなぜですか? フレックスレイアウト内の紫色のスラッシュ領域が誤って「オーバーフロー空間」と見なされるのはなぜですか? Apr 05, 2025 pm 05:51 PM

フレックスレイアウトの紫色のスラッシュ領域に関する質問フレックスレイアウトを使用すると、開発者ツールなどの混乱する現象に遭遇する可能性があります(D ...

SASSをより速くするための概念の証明 SASSをより速くするための概念の証明 Apr 16, 2025 am 10:38 AM

新しいプロジェクトの開始時に、SASSコンピレーションは瞬く間に起こります。これは、特にbrowsersyncとペアになっている場合は素晴らしい気分です。

See all articles