html js引用本地资源,【基本解决】js加载本地文件

【背景】

折腾:

期间,可以把问题转换为:

用js,去加载,读取本地的文件。

【折腾过程】

1.搜:

js load local file

js read local file

参考:

试试:function readSingleFile(e) {

var file = e.target.files[0];

if (!file) {

return;

}

var reader = new FileReader();

reader.onload = function(e) {

var contents = e.target.result;

displayContents(contents);

};

reader.readAsText(file);

}

function displayContents(contents) {

//var element = document.getElementById('file-content');

//element.innerHTML = contents;

var kindeditor = window.editor;

kindeditor.html(contents);

}

function editSavedGoodsContent()

{

console.log("into editSavedGoodsContent");

var kindeditor = window.editor;

// 加载之前已保存的页面的HTML内容

var savedHtmlHref = "previous_saved_page.html";

readSingleFile(savedHtmlHref);

}

结果:TypeError: e.target is undefined

30d121d286674a95a6a5a9c97bfe73dd.png

2.参考:

->

试试:loadedHtml = fread(savedHtmlHref,flength(savedHtmlHref));

console.log("loadedHtml=" + loadedHtml);

结果:ReferenceError: fread is not defined

-》

貌似js中没有fread。。

3.最后用

js的FileReader

基本是可以了。

4.然后想要去掉Input点击,所以去搜:

js FileReader example

参考:

不过最后还是不去掉了。

因为后面如果去掉input的file,改为直接赋值:var savedHtmlHref = "previous_saved_page.html";

则会报错,说file不是object。

所以算了,还是用这套代码吧。

【总结】

最终是用:

function readSingleFile(e) {

var file = e.target.files[0];

if (!file) {

return;

}

var reader = new FileReader();

reader.onload = function(e) {

var contents = reader.result;

displayContents(contents);

};

reader.readAsText(file);

}

function displayContents(contents) {

var kindeditor = window.editor;

kindeditor.html(contents);

}

document.getElementById('editSavedGoodsContent')

.addEventListener('change', readSingleFile, false);

function submitGoodsContent()

{

var kindeditor = window.editor;

// 取得HTML内容

html = kindeditor.html();

console.log(html);

}

商品名:

在此输入新产品的介绍内容

提交当前页面

实现了:

可以点击“浏览”按钮后,选择需要上传的文件:

4f7e4afebf948f43c9a0cb3f8cb99a67.png

点击所选html文件后,KindEditor中的内容,就加载显示所选html的内容了:

对应的 未选择文件 也变成 该所选文件名了:

d409257ce0ceeb4f81e91802560d4d35.png

如此,基本上实现了js加载本地html的效果。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值