javascript - javascript 如何在函数中创建一系列事件,以便一个函数在另一个函数完成之前不会启动?

标签 javascript

正在为个人网站编写代码,我正在尝试重写互联网上的代码,以便它对我来说更容易使用。

代码来自http://cssdeck.com/labs/7bx7mmcm

如何在 fileToLoad.click(); 之后添加一个标记?被推送并完成,然后 loadFileAsText() 继续吗?非常感谢!

<textarea id="BoxText4Load"></textarea>
<input type="file" id="fileToLoad" class="hidden">
<button id="loader">Loader</button>
<input id="inputFileNameToSaveAs" style="display: none;"></input>
<button onclick="saveTextAsFile()">Save file</button>

var loaderbutton = document.getElementById("loader");
loaderbutton.addEventListener('click', function(event){
fileToLoad.click();
setTimeout(function() {loadFileAsText(); }, 3000);
} , false)

下面的代码直接来自上面的链接:

"inputFileNameToSaveAs"

function saveTextAsFile(){
var textToWrite = document.getElementById("BoxText4Load").value;
var textFileAsBlob = new Blob([textToWrite], {type:'text/plain'});
var fileNameToSaveAs = document.getElementById("inputFileNameToSaveAs").value;

var downloadLink = document.createElement("a");
downloadLink.download = fileNameToSaveAs;
downloadLink.innerHTML = "Download File";
if (window.URL != null)
{
// Chrome allows the link to be clicked
// without actually adding it to the DOM.
downloadLink.href = window.URL.createObjectURL(textFileAsBlob);
}
else
{
// Firefox requires the link to be added to the DOM
// before it can be clicked.
downloadLink.href = window.URL.createObjectURL(textFileAsBlob);
downloadLink.onclick = destroyClickedElement;
downloadLink.style.display = "none";
document.body.appendChild(downloadLink);
}

downloadLink.click();
}

function destroyClickedElement(event)
{
document.body.removeChild(event.target);
}

function loadFileAsText()
{
var fileToLoad = document.getElementById("fileToLoad").files[0];

var fileReader = new FileReader();
fileReader.onload = function(fileLoadedEvent)
{
var textFromFileLoaded = fileLoadedEvent.target.result;
document.getElementById("BoxText4Load").value = textFromFileLoaded;
};
fileReader.readAsText(fileToLoad, "UTF-8");
}

最佳答案

我喜欢使用events只要有可能。 JavaScript 允许我们附加在发生某些事件(例如单击元素或元素更改时)时触发的函数。

您可以为#fileToLoad 添加click 事件。单击该元素后就会触发该事件。

document.getElementById("loader").addEventListener('click', function(event){
  loadFileAsText()
}

如果您希望该函数在选择文件后运行,则可以使用 change 事件。

function loadFileAsText() {
  console.log('loadFileAsText running!')
}

var loaderbutton = document.getElementById('loader')
var fileToLoad = document.getElementById('fileToLoad')

loaderbutton.addEventListener('click', function(event){
  console.log('loaderbutton clicked!')
  fileToLoad.click()
} , false)

fileToLoad.addEventListener('change', function(event){
  loadFileAsText()
})
<textarea id="BoxText4Load"></textarea>
<input type="file" id="fileToLoad" class="hidden">
<button id="loader">Loader</button>
<input id="inputFileNameToSaveAs" style="display: none;"></input>
<button onclick="saveTextAsFile()">Save file</button>

关于javascript - javascript 如何在函数中创建一系列事件,以便一个函数在另一个函数完成之前不会启动?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46325291/

相关文章:

javascript - 从文件夹中的文件生成 <img> 并将 css 样式应用于 img 或容器(基于文件名) – (Javascript/JQuery/PHP?)

javascript - Cordova 为 Android 构建错误所以我无法构建我的解决方案

javascript - Chrome 扩展 : failed to load resource for external json

javascript - Python:更新通过浏览器中的 JavaScript 调用创建的 html 时出现问题

php - 我怎样才能让这个 div 在 IE8 中扩展并溢出它的容器?

javascript - 如何正确等待状态更新/渲染而不是使用延迟/超时函数?

javascript - 获取多个 XML 文件时的 AJAX 回调

javascript - Google Apps 脚本 - 从另一个工作表导入工作表值

javascript - 使用 lodash 深度展平集合中的所有项目

javascript - 我应该在 google translate api 请求正文中放入什么参数?