加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails-4 – Material Design Lite不能与Turbolinks配合

发布时间:2020-12-16 21:43:10 所属栏目:百科 来源:网络整理
导读:我有一个简单的页面,有一个标题和抽屉导航,如下所示 我的问题是,每当我浏览到另一个页面,抽屉菜单图标(汉堡包图标)消失.我能够使用componentHandler.upgradeDom()触发图标显示;在Chrome的控制台. 我试图删除// =需要涡轮,一切都继续工作,当然是以我的页面加
我有一个简单的页面,有一个标题和抽屉导航,如下所示

我的问题是,每当我浏览到另一个页面,抽屉菜单图标(汉堡包图标)消失.我能够使用componentHandler.upgradeDom()触发图标显示;在Chrome的控制台.

我试图删除// =需要涡轮,一切都继续工作,当然是以我的页面加载速度为代价.

FYI,我把javascript移到了< body>的底部.提高第一页加载速度.我也试图将javascripts移回到< head>标签,有和没有data-turbolinks-track,问题仍然重现.

我希望MDL和Turbolinks可以一起工作,而不需要花费我(第一页)加载速度.

任何帮助非常感谢.

<body>
<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">
  <header class="mdl-layout__header">
    <div class="mdl-layout__header-row">
      <span class="mdl-layout-title"><%= yield(:title) %></span>
      <div class="mdl-layout-spacer"></div>
      <nav class="mdl-navigation mdl-layout--large-screen-only">
        <!-- some links -->
      </nav>
    </div>
  </header>
  <div class="mdl-layout__drawer">
    <span class="mdl-layout-title"><%= yield(:title) %></span>
    <nav class="mdl-navigation">
      <!-- some links -->
    </nav>
  </div>
  <main class="mdl-layout__content">
    <%= yield %>
  </main>
</div>


<%= javascript_include_tag 'https://storage.googleapis.com/code.getmdl.io/1.0.5/material.min.js','data-turbolinks-eval' => 'false' %>
<%= javascript_include_tag 'application','data-turbolinks-eval' => false %>
</body>

更新:我能够使两者一起工作的唯一方法是添加componentHandler.upgradeDom();在< body>的最末端

解决方法

另一个解决方案是使用TurboLinks的页面:change事件来调用upgradeDom.
document.addEventListener('page:change',function() {
  componentHandler.upgradeDom();
});

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读