Web存储及文件拖拽

存储

实现内容的永久保存(localStorage)

保存:

localStorage.自定义键名="123";

获取:

1 //判断是否有内容
2 if(localStorage.自定义键名){
3     //显示内容
4     alert(localStorage.自定义键名);
5 }

只在当前页面存储(sessionStorage)

保存和获取方法与上相同

缓存

CACHE MANIFEST在该标题下列出的文件将会在首次进行缓存

NETWORK 在该标题下的文件将不进行缓存

FALLBACK在该标题下的文件将会在规定页面无法访问时跳转的其它页面

开启缓存:

在html标签中添加属性manifest,并指定值为文件名

<html manifest="dongcache.appcache">

设置缓存:

创建dongcache.appcache文件

 1 CACHE MANIFEST
 2 
 3 CACHE:
 4 kk.html
 5 dong.css
 6 dong.js
 7 
 8 NETWORK:
 9 
10 FALLBACK:

文件拖拽

实现本地图片拖拽并预览

 1 var divobjx=document.getElementsByTagName("div")[0];
 2 //屏蔽系统默认事件
 3 divobjx.ondragover=function(e){
 4     e.preventDefault();
 5 }
 6 //监听拖拽事件
 7 divobjx.ondrop=function(e){
 8     e.preventDefault();
 9     var f=e.dataTransfer.files[0];//得到文件对象
10     alert(f.name+"***"+f.size+"***"+f.type);//得到文件信息
11     var fr=new FileReader();
12     
13     fr.onload=function(e){
14         divobjx.innerHTML="";
15         alert(fr.result);
16       }
17     fr.readAsDataURL(f);
18 }

表单文件内容获取:

1 <input type="file" name="setfilex" />
2 <script>
3 var ffobjx=document.getElementsByName("setfilex")[0];    
4 ffobjx.onchange=function(){
5     f=ffobjx.files[0];
6     alert(f.name+"****"+f.size+"*****"+f.type);
7 }    
8 script>

综合代码

文件上传(选择文件和拖拽文件)预览和设置到form表单上

Web存储及文件拖拽_第1张图片

 1 var ffobjx=document.getElementsByName("setfilex")[0];//得到文件表单对象    (input)
 2 //监听文件表单的内容改变
 3 ffobjx.onchange=function(){
 4     f=ffobjx.files[0];
 5     showfile(f);
 6     //alert(f.name+"****"+f.size+"*****"+f.type);
 7 }
 8 var divobjx=document.getElementById("filediv");//得到文件拖拽框对象
 9 //屏蔽系统默认事件
10 divobjx.ondragover=function(e){
11     e.preventDefault();
12 }
13 //监听拖拽事件
14 divobjx.ondrop=function(e){
15     e.preventDefault();
16     var f=e.dataTransfer.files[0];//得到文件对象
17     ffobjx.files=e.dataTransfer.files;//将拖拽信息设置到表单上    
18     showfile(fr);
19 }
20 //显示文件,暂时设置为显示图片
21 function showfile(f11){
22     //alert(f.name+"***"+f.size+"***"+f.type);//得到文件信息
23     var fr=new FileReader();
24     fr.onload=function(e){
25         divobjx.innerHTML="";
26         //alert(fr.result);
27      }
28     fr.readAsDataURL(f11);
29 }

 

你可能感兴趣的:(Web存储及文件拖拽)