将spin.js微调器插入div?

时间:2014-05-24 10:17:31

标签: javascript jquery css spin.js

刚刚找到了spin.js,它似乎是一个救生员。

问题是如何将微调器插入我的div?

我有一个关注按钮,点击后我删除了背景图片,目前用loader.gif替换。

我怎么能用spin.js做同样的事?

我敲了一个jsfiddle的简单例子:

http://jsfiddle.net/4XpHp/

我希望微调器位于红色方格内。

<div id="foo"></div>
<button id="spin"> Spin! </button>

var opts = {
  lines: 13, // The number of lines to draw
  length: 17, // The length of each line
  width: 8, // The line thickness
  radius: 21, // The radius of the inner circle
  corners: 1, // Corner roundness (0..1)
  rotate: 58, // The rotation offset
  direction: 1, // 1: clockwise, -1: counterclockwise
  color: '#fff', // #rgb or #rrggbb or array of colors
  speed: 0.9, // Rounds per second
  trail: 100, // Afterglow percentage
  shadow: false, // Whether to render a shadow
  hwaccel: false, // Whether to use hardware acceleration
  className: 'spinner', // The CSS class to assign to the spinner
  zIndex: 2e9, // The z-index (defaults to 2000000000)
  top: '50%', // Top position relative to parent
  left: '50%' // Left position relative to parent
};

$("#spin").click(function(){
  var target = document.getElementById('foo');
  var spinner = new Spinner(opts).spin(target);
});

#foo {
    width: 50px;
    height: 50px;
    background-color: #f00;
}

2 个答案:

答案 0 :(得分:6)

你只需要设置:

#foo {
   position: relative; //Added this
   width: 50px;
   height: 50px;
   background-color: #f00;
}

<强> JsFiddle

这实际上是一个css问题。默认情况下,.spinner div设置为position: absolute(并且您无法使用css更改它,因为它是内联样式),这意味着它将位于nearest positioned ancestor的中间位置,我假设是<body>标签(请随时在此纠正我)。通过使#foo具有相对位置,它将成为定位的祖先,并且微调器将位于其中。

答案 1 :(得分:0)

我更新了你的小提琴,让它做你想做的事。我只需要调整一些配置值以使顶部和左侧位置正确,然后调整微调器本身的大小。

http://jsfiddle.net/4XpHp/2/

var opts = {
    lines: 10, // The number of lines to draw
    length: 7, // The length of each line
    width: 2, // The line thickness
    radius: 5, // The radius of the inner circle
    corners: 1, // Corner roundness (0..1)
    rotate: 58, // The rotation offset
    direction: 1, // 1: clockwise, -1: counterclockwise
    color: '#fff', // #rgb or #rrggbb or array of colors
    speed: 0.9, // Rounds per second
    trail: 100, // Afterglow percentage
    shadow: false, // Whether to render a shadow
    hwaccel: false, // Whether to use hardware acceleration
    className: 'spinner', // The CSS class to assign to the spinner
    zIndex: 2e9, // The z-index (defaults to 2000000000)
    top: '12%', // Top position relative to parent
    left: '6.5%' // Left position relative to parent
};