angularjs - 缩小后角度 ui-select 中断
问题描述
我目前需要维护一个使用 angular-ui-select 0.19.8 的 angular.js 1.5 应用程序。我遇到的问题是,打包应用程序时 ui-select 会以某种方式中断。运行时grunt serve
,这部分:
<ui-select mandatory-field-marker
multiple ng-required="true"
ng-model="some.periods">
<ui-select-match placeholder="Select some periods...">
{{$item | period}}
</ui-select-match>
<ui-select-choices
repeat="period in formCtrl.periods">
<div ng-bind-html="period | highlight: $select.search"></div>
</ui-select-choices>
</ui-select>
这不仅仅是样式问题,损坏的输入字段不允许超过 10 个元素,然后由于转移到下一个组件而变得不可点击。
打包是用 grunt 完成的,据我所知,这些是用于缩小代码的步骤:
useminPrepare
concat
ngAnnotate
imagemin
autoprefixer
cssmin
usemin
htmlmin
我找到了一些解决方法,比如降级 ui-select 并添加匹配的类<ui-select>
,<ui-select-choices>
但它们都没有奏效。
bower 拉取的 ui-select 依赖项似乎已经被缩小了:
更新:这似乎是 grunt 和/或 bower 的问题。重新配置托管网站的 Apache 后,我遇到了错误,即vendor.min.css
丢失。我在(由 bower 生成)index.html 头中找到了它说的部分:
<!-- build:css(.) styles/vendor.min.css -->
<!-- bower:css -->
<link rel="stylesheet" href="bower_components/angular-ui-select/dist/select.css" />
<link rel="stylesheet" href="bower_components/ng-tags-input/ng-tags-input.css" />
<!-- endbower -->
<!-- endbuild -->
<!-- build:css(.) styles/bootstrap.min.css -->
<link rel="stylesheet" href="styles/bootstrap.css">
<!-- endbuild -->
<!-- build:css(.) styles/main.min.css -->
<link rel="stylesheet" href="styles/main.css">
<!-- endbuild -->
但是,只有bootstrap.min.css
andmain.min.css
被打包到我的 dist 中:
还是不知道原因。
解决方案
我已经修复了它,但不是很优雅。问题是,select.css 和 ng-tags-input.css 没有打包到 vendor.min.css 中,所以它们在部署后丢失了。我无法确定哪个 grunt-task 应该构建 vendor.min.css,但至少我知道应该由谁来做,没有。所以在 index.html 我改变了部分
<!-- build:css(.) styles/vendor.min.css -->
<!-- bower:css -->
<link rel="stylesheet" href="bower_components/angular-ui-select/dist/select.css" />
<link rel="stylesheet" href="bower_components/ng-tags-input/ng-tags-input.css" />
<!-- endbower -->
<!-- endbuild -->
<!-- build:css(.) styles/bootstrap.min.css -->
<link rel="stylesheet" href="styles/bootstrap.css">
<!-- endbuild -->
<!-- build:css(.) styles/main.min.css -->
<link rel="stylesheet" href="styles/main.css">
<!-- endbuild -->
至
<!-- build:css(.) styles/select.min.css -->
<link rel="stylesheet" href="bower_components/angular-ui-select/dist/select.css" />
<!-- endbuild -->
<!-- build:css(.) styles/ng-tags-input.min.css -->
<link rel="stylesheet" href="bower_components/ng-tags-input/ng-tags-input.css" />
<!-- endbuild -->
<!-- build:css(.) styles/bootstrap.min.css -->
<link rel="stylesheet" href="styles/bootstrap.css">
<!-- endbuild -->
<!-- build:css(.) styles/main.min.css -->
<link rel="stylesheet" href="styles/main.css">
<!-- endbuild -->
现在有效。这将是一个问题,如果将来还有来自 bower_components 的 css-files,但我正在谈论的应用程序将在明年停止服务,所以没关系。
推荐阅读
- angular - 在 cmd 中输入 ng serve --open 时出错
- ios - 垂直堆栈视图内的三个 UIButton。单击第一个按钮也会触发最后一个按钮
- python - 使用条件逻辑从 pandas df 创建多个列表
- ruby - Chef 自定义资源属性
- c++ - char 指针的内存释放
- postgresql - 如何累积从负值开始的行,直到结果为正?
- javascript - Node/Puppeteer:尝试使用选择器获取所有链接,获取结果属性
- python-3.x - PyInstaller exe 仅适用于 -F 选项
- r - randomForest.default(x, y, mtry = param$mtry, ...) 中的错误:需要至少两个类来进行分类
- ios - 刷新 TabView 选项卡中的数据