Rails6默认再也不使用asset pipeline,改用Webpacker。javascript
文件结构变化:css
下图是默认生成的文件夹。包含了rails UJS库, turbolinks, atcivestorage, channelshtml
添加了channels文件夹。java
如何安装一个packer:webpack
# 例如 rails webpacker:install:stimulus
Appending Stimulus setup code to /Users/.../tailwindapp/app/javascript/packs/application.js append app/javascript/packs/application.js
# 增长了一行代码import "controllers"
Creating controllers directory create app/javascript/controllers create app/javascript/controllers/hello_controller.js create app/javascript/controllers/index.js Installing all Stimulus dependencies run yarn add stimulus from "."
#安装依赖包,能够在yarn.lock中看到详细说明
一个轻量化的datetime picker。web
包括使用JS和CSSnpm
安装:app
# using npm install npm i flatpickr --save # 其余 yarn add flatpickr #cdn也能够
推荐直接使用元素,或者选择器:post
// If using flatpickr in a framework, its recommended to pass the element directly flatpickr(element, {}); // Otherwise, selectors are also supported flatpickr("#myID", {}); // creates multiple instances flatpickr(".anotherSelector");
1. 生成一个Post
下面的命令仍然会生成assetpipeline的文件: stylesheets/scaffolds.scss,若是不使用就删除掉。
rails g scaffold Post title publish_date:date
2. yarn add flatpickr
javascript/packs/application.js内添加:
import flatpickr from "flatpickr";
#只使用flatpickr的CSS样式
require("flatpickr/dist/flatpickr.css")
#或者使用不一样的样式主题
#require("flatpickr/dist/themes/light.css")
document.addEventListener("turbolinks:load", () => {
flatpickr("[data-behavior='flatpickr']", {
altInput: true,
altFormat: "F j, Y",
dateFormat: "Y-m-d"
})
})
在application.html.erb添加:(使用webPacker CSS)
<%= stylesheet_pack_tag 'application', media: "all", ...%>
在对应的视图文件内添加:
<div> <%= form.text_field :publish_date, data: {behavior: 'flatpickr'}%> </div>
#生成<input data-behavior="flatpickr" type="hidden" name="post[publish_date]" id="post_publish_date" class="flatpickr-input">