javascript - 基金会 6 : How to add tabs using jquery

标签 javascript jquery tabs zurb-foundation

我正在尝试使用 jquery 在基础中添加一个选项卡。看我的演示代码:

<!DOCTYPE html>
<html>
  <head>
      <meta charset="UTF-8">
      <title>Tab Test</title>
      <link href="foundation-6/css/foundation.css" type="text/css" rel="stylesheet">
      <script src="jquery-2.2.0.js"></script>
      <script src="foundation-6/js/foundation.js"></script>
  </head>

  <body>
    <div class="row"><div class="large-12 columns"><button type="button" id="button1">Click Me!</button></div></div>
    <div class="row collapse">
      <div class="medium-3 columns">
        <ul class="tabs vertical" id="example-vert-tabs" data-tabs>
          <li class="tabs-title is-active"><a href="#panel1v" aria-selected="true">Tab 1</a></li>
          <li class="tabs-title"><a href="#panel2v">Tab 2</a></li>
          <li class="tabs-title"><a href="#panel3v">Tab 3</a></li>
          <li class="tabs-title"><a href="#panel4v">Tab 4</a></li>
          <li class="tabs-title"><a href="#panel5v">Tab 5</a></li>
          <li class="tabs-title"><a href="#panel6v">Tab 6</a></li>
        </ul>
        </div>
        <div class="medium-9 columns">
        <div class="tabs-content vertical" data-tabs-content="example-vert-tabs" id="tab_content">
          <div class="tabs-panel is-active" id="panel1v">
            <p>Test1</p>
          </div>
          <div class="tabs-panel" id="panel2v">
            <p>Test2</p>
          </div>
          <div class="tabs-panel" id="panel3v">
            <p>Test3</p>
          </div>
          <div class="tabs-panel" id="panel4v">
            <p>Test4</p>
          </div>
          <div class="tabs-panel" id="panel5v">
            <p>Test5</p>
          </div>
          <div class="tabs-panel" id="panel6v">
            <p>Test6</p>
          </div>
        </div>
      </div>
    </div>
    <script>
      $(document).ready(function() {
        $(document).foundation();

        $("#button1").click(function() {
          $("#example-vert-tabs").append('<li class="tabs-title"><a href="#panel7v">Tab 7</a></li>');
          $("#tab_content").append('<div class="tabs-panel" id="panel7v"><p>Test7</p></div>');
          $(".tabs").foundation();
        });
      });
    </script>
  </body>
</html>

但是当我点击按钮时,我收到了以下警告:“试图在一个已经有 Foundation 插件的元素上初始化选项卡。”我无法点击新标签页。

当我点击时出现这个错误:

7123TypeError: undefined is not an object (evaluating '$tabLink[0].hash')
_handleTabChangefoundation.js:7122
(anonymous function)foundation.js:7059
dispatchjquery-2.2.0.js:4731
handlejquery-2.2.0.js:4543

怎么了?

最佳答案

代码中的基本问题是如何初始化选项卡实例。

在基础 6 中,为了创建一个新的选项卡实例 (link),您应该在您的 js 代码中添加如下内容:

var elem = new Foundation.Tabs($('#example-vert-tabs'));

然后每次您进行更改并添加或删除选项卡时,您都可以调用如下内容:

elem = new Foundation.Tabs($('#example-vert-tabs'));

我已经用您的代码创建了一个 codepen 示例,这样您就可以准确地看到发生了什么 ( http://codepen.io/MKallivokas/pen/xVgrYM ):

$(document).ready(function() {
    var elem = new Foundation.Tabs($('#example-vert-tabs'));

    $("#button1").click(function() {
          $("#example-vert-tabs").append(
            '<li class="tabs-title"><a href="#panel7v">Tab 7</a></li>'
          );
          $("#tab_content").append(
            '<div class="tabs-panel" id="panel7v"><p>Test7</p></div>'
          );

          elem = new Foundation.Tabs($('#example-vert-tabs'));
    });
});

关于javascript - 基金会 6 : How to add tabs using jquery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35459878/

相关文章:

jquery - 这个移动的火箭是否使用 CSS3(动画)?

jQuery 将输入类型=文本更改为文本区域

javascript - 单击时使用选项卡在页面底部显示隐藏的内容

javascript - 表单提交时出现 jquery 错误

javascript - jQuery 在 .find() 之后使用选择器

javascript - 如何在 angularJS 中跟踪数组索引?

reactjs - 当我重新加载页面时,Material-UI 选项卡指示器返回到第一个选项卡项

javascript - 如何在加载、后退和前进时运行函数

javascript - 从自身内部调用函数

python - 每 x 秒执行一次 Python 而无需重新打开选项卡