为了使Foundation 6的响应菜单起作用,我应该在UnCSS插件上忽略什么字符串?

问题描述 投票:3回答:2

[我在NPM上安装了Foundation 6,并通过foundation new命令启动了一个新项目,并开始构建一个新网站。但是,当我使用命令foundation build --production在生产环境上构建它时,即使使用大型监视器,也要折叠.top-bar类(请注意data-hide-for="medium")。当我使用foundation watch命令在开发模式下运行它时,它就可以正常工作(仅在中小型设备上崩溃)。

我以为可能有一些吞吞吐吐的问题,所以我决定一个一个地测试。当我将uncss修改为仅在开发模式下运行时(将isProduction var更改为false布尔值),就可以了!因此,我决定阅读他们的文档,并在那里找到“忽略”设置。我可以在其中设置一些选择器,这就是我的问题。我必须忽略什么选择器才能使折叠效果良好?我认为UnCSS正在删除一些它认为* .html文件未使用的选择器,但确实没有,我无法确定它是哪个选择器。

注意: uncss任务仅在生产模式下运行。

index.html

<div class="title-bar" data-responsive-toggle="top-menu" data-hide-for="medium">
    <button class="menu-icon" type="button" data-toggle></button>
    <div class="title-bar-title">Menu</div>
</div>

<div class="top-bar" id="top-menu">
    <div class="top-bar-left">
        <ul class="dropdown menu" data-dropdown-menu>
            <li class="menu-text">Site Title</li>
            <li class="has-submenu">
                <a href="#">One</a>
                <ul class="submenu menu vertical" data-submenu>
                    <li><a href="#">One</a></li>
                    <li><a href="#">Two</a></li>
                    <li><a href="#">Three</a></li>
                </ul>
            </li>
            <li><a href="#">Two</a></li>
            <li><a href="#">Three</a></li>
        </ul>
    </div>
    <div class="top-bar-right">
        <ul class="menu">
            <li>
                <input type="text" placeholder="Login">
            </li>
            <li>
                <input type="password" placeholder="Password">
            </li>
            <li>
                <button type="button" class="button">Login</button>
            </li>
        </ul>
    </div>
</div>

gulpfile.js(这是Foundation for Sites完整模板的默认设置,因此我只放置CSS编译部分)

// Compile Sass into CSS
// In production, the CSS is compressed
gulp.task('sass', function() {
  var uncss = $.if(isProduction, $.uncss({
    html: ['src/**/*.html'],
    ignore: [
      new RegExp('^meta\..*'),
      new RegExp('^\.is-.*')
    ]
  }));

  var minifycss = $.if(isProduction, $.minifyCss());

  return gulp.src('src/assets/scss/app.scss')
    .pipe($.sourcemaps.init())
    .pipe($.sass({
      includePaths: PATHS.sass
    })
      .on('error', $.sass.logError))
    .pipe($.autoprefixer({
      browsers: COMPATIBILITY
    }))
    .pipe(uncss)
    .pipe(minifycss)
    .pipe($.if(!isProduction, $.sourcemaps.write()))
    .pipe(gulp.dest('dist/assets/css'))
    .pipe(browser.reload({stream: true}));
});

整个CSS未被修改,即使路径是默认值,我也没有做任何修改(但是我添加了一些规则,例如字体和一些颜色),我只是删除了Foundation 6的默认index.html并添加了此菜单(在他们的文档上)。

[为了帮助您,我在MEGA上单击uploaded the whole project,只需将其解压缩并运行foundation watch,请参阅.top-bar正常工作(带有菜单和登录表单),然后运行foundation build --production并运行index.html ]从dist文件夹中查看,然后折叠.top-bar

.top-bar在生产中:enter image description here

.top-bar关于开发(工作中):enter image description here

javascript gulp zurb-foundation uncss
2个回答
1
投票

我有一个类似的问题,并通过以下gulp-uncss设置进行了修复:

   .pipe(uncss({
      html: ['./*.html'],
      ignore: [new RegExp('^meta\..*'),
        new RegExp('.*\.is-.*'),
        new RegExp('.*\.top-bar.*'),
        new RegExp('.*\.menu.*')]
    }))

0
投票

foundation-mq类添加到忽略列表。只有正则表达式对我有用:/foundation\-mq/


_global.scss

// These styles are applied to a <meta> tag, which is read by the Foundation JavaScript
.foundation-mq {
  font-family: '#{-zf-bp-serialize($breakpoints)}';
}
© www.soinside.com 2019 - 2024. All rights reserved.