Maison  >  Article  >  interface Web  >  实例帮助你了解HTML5滑动区域选择元素Slider element

实例帮助你了解HTML5滑动区域选择元素Slider element

PHP中文网
PHP中文网original
2017-03-24 10:40:596274parcourir

       HTML5的出现带给我们了很多新的标签和元素。其中一个就是区间选择输入元素,例如,选择10以内的一个数字。这个元素其实在很多系统操作系统中都存在了很长时间,但是现在只是如何将他们整合到浏览器中。
       因为使用JS可以很方便的模拟出这个效果所以HTML中一直没有可以直接使用的滑动选择元素。jQuery UI类库包含了一个非常不错的版本可以很容易进行样式设置。但是整合到浏览器中将非常简单,支持对于支持它的浏览器来说。

959.jpg

       浏览器支持
       除了著名的Firefox外所有的现代浏览器都支持这个元素,但是很容易使用html5slider.js来创建。当然IE也不支持区域选择输入,这个修改不太容易。这样的话,意味着你需要使用分开的类库类似jQuery UI来支持多浏览器。好消息在于如果浏览器不支持区域选择的话,它会做为一个输入框显示。

960.jpg

       如何工作的?
       区域选择输入元素使用输入框类似的标签,支持一般的数值属性,及其min和max,用来限制区域,step用来设置滑动中数值增量。缺省为1。

961.jpg

       你可以使用JS/jQuery来修改这些属性,也可以使用onchange事件来监听变化。代码如下:

<input id="defaultSlider" type="range" min="0" max="500" />
<p class="note">Current value: <span id="currentValue">0</span></p>

       或者

$(function(){
        var currentValue = $(&#39;#currentValue&#39;);
        $(&#39;#defaultSlider&#39;).change(function(){
            currentValue.html(this.value);
        });
        // Trigger the event on load, so
        // the value field is populated:
        $(&#39;#defaultSlider&#39;).change();
});

       当然这些代码需要浏览器支持。否则你只能看到一个输入框。
       当然2/3的浏览器都看不到我们这个区域选择输入,我们需要想想别的方法。我们先快速使用jQueryUI来实现一个滑动选择器。

<p id="slider"></p>
<p class="note">Current value: <span id="currentValue">0</span></p>

       你可以看到代码如下:

$(function(){
        var currentValue = $(&#39;#currentValue&#39;);
        $("#slider").slider({
                max: 500,
                min: 0,
                slide: function(event, ui) {
                        currentValue.html(ui.value);
                }
        });
});
  1. 代码非常简单。使用slider方法来实现。       

  2. 最有意思的部分      

  3. 因为我们已经实现了自己的区域选择方法,大家可以参考演示

  4.        slider-knob.html

<p id="container">
        <p id="control"></p>
</p>

<!-- The range input is hidden and updated on each rotation of the knob -->
<input type="range" id="slider" min="0" max="500" value="25" />

<p class="note">Current value: <span id="currentValue">0</span></p>

       assets/js/slider-knob.js

$(function(){
        var slider = $(&#39;#slider&#39;),
                min = slider.attr(&#39;min&#39;),
                max = slider.attr(&#39;max&#39;),
                currentValue = $(&#39;#currentValue&#39;);
        // Hiding the slider:
        slider.hide();
        $(&#39;#control&#39;).knobKnob({
                snap : 10,
                value: 250,
                turn : function(ratio){
                        // Changing the value of the hidden slider
                        slider.val(Math.round(ratio*(max-min) + min));
                        // Updating the current value text
                        currentValue.html(slider.val());
                }
        });
});

       以上代码使用min和max来计算数值。
       总结
       滑动选择对于用户使用来说比输入框非常方便 。虽然浏览器支持有限,但是你可以使用jQuery来增强相关功能。

以上就是实例帮助你了解HTML5滑动区域选择元素Slider element的内容,更多相关内容请关注PHP中文网(www.php.cn)!

相关文章:

hwSlider-内容滑动切换效果(一)

hwSlider-内容滑动切换效果(二):响应式可触控滑动

微信小程序 slider组件详细介绍

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn