Javascript 在 Stimulus 控制器中使用的代码重构
Javascript code refactor to use in Stimulus controller
如何像这样重构JS代码:
const fileInput = document.getElementById('input');
const p = document.querySelector('p');
fileInput.onchange = () => {
const selectedFiles = [...fileInput.files];
p.textContent = selectedFiles.map(s => s.size).join(', ');
}
使其在 rail's Stimulus 中发挥作用?
我对 JS 的经验很少,想有一两个在 Stimulus 控制器中实现 JS 代码的例子,所以我有 material 可以自己重构其他案例。
非常感谢。
一个可能的解决方案:
<div data-controller="file">
<input type="file" data-file-target="input" data-action="change->file#displayText" id="my-input">
<output data-file-target="text" for="my-input"></output>
</div>
// filename_controller.js
// Connects to data-controller="file"
export default class extends Controller {
static targets = ["input", "text"]
displayText() {
const selectedFiles = [...thisInputTarget.files];
this.textTarget.textContent = selectedFiles.map(s => s.size).join(', ');
}
}
如何像这样重构JS代码:
const fileInput = document.getElementById('input');
const p = document.querySelector('p');
fileInput.onchange = () => {
const selectedFiles = [...fileInput.files];
p.textContent = selectedFiles.map(s => s.size).join(', ');
}
使其在 rail's Stimulus 中发挥作用? 我对 JS 的经验很少,想有一两个在 Stimulus 控制器中实现 JS 代码的例子,所以我有 material 可以自己重构其他案例。 非常感谢。
一个可能的解决方案:
<div data-controller="file">
<input type="file" data-file-target="input" data-action="change->file#displayText" id="my-input">
<output data-file-target="text" for="my-input"></output>
</div>
// filename_controller.js
// Connects to data-controller="file"
export default class extends Controller {
static targets = ["input", "text"]
displayText() {
const selectedFiles = [...thisInputTarget.files];
this.textTarget.textContent = selectedFiles.map(s => s.size).join(', ');
}
}