【发布时间】:2015-12-09 17:49:48
【问题描述】:
我实现了spectrum color picker,我想将颜色选择器添加到可拖动元素。 (我通过JQuery UI实现了可拖动元素。)这样,当你拖动可拖动元素时,颜色选择器会随之而来。
我可以在颜色选择器设置中使用appendTo: "parent" 来实现它。现在我有另一个问题。颜色选择器有两个主要的东西。 1 - 它有一个预定义的调色板。 2 - 它有一个颜色选择器,您可以在其中选择自定义颜色。
假设父元素是 200px(可拖动元素)。由于颜色选择器现在是父元素的子元素,颜色选择器将尝试根据父元素调整其宽度。结果是,颜色选择器位于预定义的调色板下方。这不是默认外观。
如何让颜色选择器容器拥有自己的宽度,而不依赖于父宽度?
JSFiddle
(将#wrapper的宽度设为500px即可看到默认外观。)
$("#wrapper").draggable();
$("#colorPicker").spectrum({
appendTo: "parent",
showPalette: true,
});
#wrapper {
width: 200px; /* Try Making this to 500px to see the default appearance.*/
height: 100px;
border: 1px solid grey;
text-align: center;
}
#colorPicker {
background-color: pink;
margin-top: 30px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script type="text/javascript" src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
<link rel="stylesheet" type="text/css" href="//code.jquery.com/ui/1.11.4/themes/ui-lightness/jquery-ui.css">
<script src="http://bgrins.github.io/spectrum/spectrum.js"></script>
<link href="http://bgrins.github.io/spectrum/spectrum.css" rel="stylesheet" />
<div id="wrapper">Drag Me
<div id="colorPicker">
Click Me
</div>
</div>
【问题讨论】:
-
您是否为#wrapper 尝试过“溢出:可见”?
-
@Johannes 刚刚尝试过。它不起作用
标签: javascript jquery css jquery-ui spectrumjs