Home > Article > Web Front-end > JS code to make txt file upload preview
This time I will bring you JS code to make a txt file upload preview. What are the precautions for making a txt file upload preview with JS code? The following is a practical case, let’s take a look.
The form button uses js’s onchange="uploadfile()"
event, the function code is as follows:
//此处为txt文件上传预览的js代码 function uploadfile(){ var file=$("#txt")[0].files[0]; //判断上传文件是不是txt格式,判断后缀是不是.txt if(file.name.substr(-4).toLocaleLowerCase() != '.txt'){ alert("请上传格式为txt的文件!"); windows.location="test.jsp";//重新定位到上传txt文件页面 } else//如果上传文件是txt文件,则显示文件的预览 { var reader=new FileReader; reader.readAsText(file,'gb2312'); //reader.readAsDataURL(file); reader.onload=function(evt){ var data=evt.target.result; $('#textarea_id').val(data); } } }
The effect is as follows:
Prompt for uploading file type error
Supplement:
js Upload file preview
1. FILE API
HTML5 provides two methods, FIle and FileReader, which can read file information and read files.
2. example
<p style="border: 1px solid rgb(204, 204, 204); width: 100%; height: 200px; background-size: contain; background-repeat: no-repeat; background-position: center center;"> </p> <br> <p></p> <br> <input> <script> var fileInput = document.getElementById('test-image-file'), info = document.getElementById('test-file-info'), preview = document.getElementById('test-image-preview'); // 监听change事件: fileInput.addEventListener('change', function () { // 清除背景图片: preview.style.backgroundImage = ''; // 检查文件是否选择: if (!fileInput.value) { info.innerHTML = '没有选择文件'; return; } // 获取File引用: var file = fileInput.files[0]; // 获取File信息: info.innerHTML = '文件: ' + file.name + '<br>' + '大小: ' + file.size + '<br>' + '修改: ' + file.lastModifiedDate; if (file.type !== 'image/jpeg' && file.type !== 'image/png' && file.type !== 'image/gif') { alert('不是有效的图片文件!'); return; } // 读取文件: var reader = new FileReader(); reader.onload = function(e) { var data = e.target.result; // 'data:image/jpeg;base64,/9j/4AAQSk...(base64编码)...' preview.style.backgroundImage = 'url(' + data + ')'; }; // 以DataURL的形式读取文件: reader.readAsDataURL(file); }); </script>
The file read in the form of DataURL is a string, similar to data:image/jpeg;base64,/9j/4AAQSk ...(base64 encoding)...,
is often used to set images. If server-side processing is required, send the base64 string and subsequent characters to the server and decode it with Base64 to obtain the binary content of the original file.
3. Explanation
The above code also demonstrates an important feature of JavaScript which is the single-threaded execution mode. In JavaScript, the browser's JavaScript execution engine always executes in single-threaded mode when executing JavaScript code. That is to say, JavaScript code cannot be executed by more than one thread at the same time at any time.
You may ask, how does JavaScript executed in single-threaded mode handle multitasking?
In JavaScript, multitasking is actually asynchronous call, such as the above code:
reader.readAsDataURL(file);
An asynchronous operation will be initiated to read the file contents. Because it is an asynchronous operation, we do not know when the operation ends in the JavaScript code, so we need to set a callback function first:
reader.onload = function(e) { // 当文件读取完成后,自动调用此函数: };
When the file reading is completed, the JavaScript engine will automatically call the callback we set function. When the callback function is executed, the file has already been read, so we can safely obtain the file contents inside the callback function.
I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!
Recommended reading:
Convert html string to HTML tag and use
How to customize operation login in Vue.js Form code
The above is the detailed content of JS code to make txt file upload preview. For more information, please follow other related articles on the PHP Chinese website!