使用wrapInner进行jQuery滑动,然后在完成后删除

标签 jquery firefox cross-browser fieldset

在 jquery 中使用向上/向下滑动功能时,我遇到了 Firefox 错误 ( overflow property not implemented on fieldset )。

所以我想:

  1. 点击时通过 jquery 添加内部 div
  2. 向上/向下滑动此 div
  3. 删除内部div

这是我到目前为止所拥有的:

var $searchBtn = $form.find('.search-reveal');          
$searchBtn.click(function(e){               
    var $this = $(this),
        $fieldset = $this.next();

    $this.toggleClass('open');

    // FIX Firefox bug - https://bugzilla.mozilla.org/show_bug.cgi?id=261037
    var $fieldsetInner = $fieldset.children().eq(0)
    if(!$fieldsetInner.is("div")){
        $fieldsetInner = $fieldset.innerWrap("<div></div>");
    }

    if($this.hasClass('open')){
        $fieldset.addClass('open');
        $form.addClass('active');
        $fieldsetInner.slideDown('fast', 'easeInQuad', function(){
            // REMOVE Firefox bug fix
        });
    } else {
        $fieldsetInner.slideUp('fast', 'easeOutQuad', function(){
            $fieldset.removeClass('open');
            $form.removeClass('active');
            // REMOVE Firefox bug fix
        });
    }

    e.preventDefault();
});

我已经尝试过this建议使用 display: table-column 修复,但这没有什么区别。

最佳答案

我编写了一个独立的 jQuery 函数来执行此操作:

$.fn.fieldsetSlideToggle = function (speed) {
    var $this = $(this),
        $inner = $this.children().eq(0),
        display = $this.css('display'),
        slideSpeed = speed ? speed : 'fast';

    // 1. Check if first child of fieldset is <div>
    // 2. Wrap contents in <div> if not
    if (!$inner.is("div")) {
        $inner = $('<div />').html($this.html());
        $this.empty().append($inner);
    }

    // 3. SlideToggle on div
    if (display == 'none') {
        $this.show();
        $inner.hide().slideDown(slideSpeed, function () {
            $this.html($inner.html());
        });
    } else {
        $inner.slideUp(slideSpeed, function () {
            $this.html($inner.html()).hide();
        });
    }
}

fiddle :http://jsfiddle.net/tbDRu/6/ 。单击按钮可向上/向下滑动字段集。

关于使用wrapInner进行jQuery滑动,然后在完成后删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18046043/

相关文章:

javascript - 使用 jQuery 生成 JSON

javascript - 如何将 Greasemonkey 脚本转换为无需重启的 Firefox 插件?

javascript - 无法在 Firefox canvas 中绘制斜体文本

css - 使用 .ico 文件作为光标

jquery - 在元素级别覆盖核心 jQuery 函数

php - 使 Web 应用程序开源

javascript - 我可以知道 Firefox 跟踪保护何时在 javascript 代码中打开吗?

html - 样式输入类型文件?

http - 新选项卡或窗口中的跨浏览器客户端重定向

javascript - 所有大写文本。有没有办法正确修复 CAPITALIZED 用户输入?