it-swarm.com.ru

JQuery UI Color Picker

Я слышал, что jQuery UI включает в себя Color Picker, но не смог найти документации по этому поводу.

Это существует?

Любая достойная документация о том, как это реализовать?

Я нашел это: http://docs.jquery.com/UI/Colorpicker

Но используя:

$("#colorpicker").colorpicker();

не работает, Firebug говорит мне, что .colorpicker(); это не метод!

Кажется, он работает нормально, если я не помещу его в диалоговый интерфейс, где он затем решает сломаться.

54
Damien

Вы можете найти некоторые демонстрации и плагины здесь.

http://jqueryui.pbworks.com/ColorPicker

39
shin

Возможно, я очень опоздал, но на данный момент есть другой способ использовать его с помощью jquery ui слайдер .

Вот как это показано в документации по jquery ui:

function hexFromRGB(r, g, b) {
    var hex = [
      r.toString( 16 ),
      g.toString( 16 ),
      b.toString( 16 )
    ];
    $.each( hex, function( nr, val ) {
      if ( val.length === 1 ) {
        hex[ nr ] = "0" + val;
      }
    });
    return hex.join( "" ).toUpperCase();
  }
  function refreshSwatch() {
    var red = $( "#red" ).slider( "value" ),
      green = $( "#green" ).slider( "value" ),
      blue = $( "#blue" ).slider( "value" ),
      hex = hexFromRGB( red, green, blue );
    $( "#swatch" ).css( "background-color", "#" + hex );
  }
  $(function() {
    $( "#red, #green, #blue" ).slider({
      orientation: "horizontal",
      range: "min",
      max: 255,
      value: 127,
      slide: refreshSwatch,
      change: refreshSwatch
    });
    $( "#red" ).slider( "value", 255 );
    $( "#green" ).slider( "value", 140 );
    $( "#blue" ).slider( "value", 60 );
  });
#red, #green, #blue {
float: left;
clear: left;
width: 300px;
margin: 15px;
}
#swatch {
width: 120px;
height: 100px;
margin-top: 18px;
margin-left: 350px;
background-image: none;
}
#red .ui-slider-range { background: #ef2929; }
#red .ui-slider-handle { border-color: #ef2929; }
#green .ui-slider-range { background: #8ae234; }
#green .ui-slider-handle { border-color: #8ae234; }
#blue .ui-slider-range { background: #729fcf; }
#blue .ui-slider-handle { border-color: #729fcf; }
<link rel="stylesheet" href="//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css">

<script src="//code.jquery.com/jquery-1.10.2.js"></script>
<script src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
<p class="ui-state-default ui-corner-all ui-helper-clearfix" style="padding:4px;">
  <span class="ui-icon ui-icon-pencil" style="float:left; margin:-2px 5px 0 0;"></span>
  Simple Colorpicker
</p>
 
<div id="red"></div>
<div id="green"></div>
<div id="blue"></div>
 
<div id="swatch" class="ui-widget-content ui-corner-all"></div>
6
Kakar

Убедитесь, что на вашей странице есть база jQuery UI и виджет для выбора цвета (а также копия jQuery 1.3):

<link rel="stylesheet" href="http://dev.jquery.com/view/tags/ui/latest/themes/flora/flora.all.css" type="text/css" media="screen" title="Flora (Default)">

<script type="text/javascript" src="http://dev.jquery.com/view/tags/ui/latest/ui/ui.core.js"></script>

<script type="text/javascript" src="http://dev.jquery.com/view/tags/ui/latest/ui/ui.colorpicker.js"></script>

Если они есть, попробуйте опубликовать свой источник, чтобы мы могли видеть, что происходит.

2
ajm

Это потому, что вы пытаетесь получить доступ к плагину до его загрузки. Вы должны попытаться позвонить ему, когда DOM загружен, окружив его следующим:

$(document).ready(function(){
    $("#colorpicker").colorpicker();
}
1
Dzhuneyt

Была такая же проблема (это не метод) с jQuery при работе с автозаполнением. Оказалось, что код был выполнен до загрузки autocomplete.js. Поэтому убедитесь, что ui.colorpicker.js загружен перед вызовом colorpicker.

1
RvdK