本站业务范围:1、PC端软件开发、网站开发 2、移动端APP、网站、微信接口、微商城开发 3、视频教程、课程设计和辅导 4、单片机开发 5、串口通讯调试
 当前位置:文章中心 >> Css3.0_css2.0_html5
立即购买视频教程 拖放API中源对象与目标对象事件间的数据传递
夜鹰教程网 来源:www.yyjcw.com 日期:2017-11-20 14:00:56
拖放API中源对象与目标对象事件间的数据传递

这篇文章不能解决你的问题?我们还有相关视频教程云课堂 全套前端开发工程师培训课程

微信号:yyjcw10000 QQ:1416759661  远程协助需要加QQ!

业务范围:视频教程|程序开发|在线解答|Demo制作|远程调试| 点击查看相关的视频教程

技术范围:全端开发/前端开发/webapp/web服务/接口开发/单片机/C#/java/node/sql server/mysql/mongodb/android/。 



1、拖放API中源对象与目标对象事件间的数据传递: ①创建全局变量——污染全局对象: var 全局变量=null; src.ondragstart=function(){ 全局变量=数据值; } target.ondrop=function(){ console.log(全局变量); } ②使用HTML5中拖放API提供的dataTransfer对象

1、拖放API中源对象与目标对象事件间的数据传递:

 ①创建全局变量——污染全局对象:

  var 全局变量=null;

  src.ondragstart=function(){

   全局变量=数据值;

  }

  target.ondrop=function(){

   console.log(全局变量);

  }

 ②使用HTML5中拖放API提供的dataTransfer对象:

  源对象事件的dataTransfer与目标对象事件的dataTransfer不是同一个对象,但可相互传递数据;

  src.ondragstart=function(e){

   e.dataTransfer.setData('key','value');

  }

  target.ondrop=function(e){

   //读取数据传递对象中得到的数据

   var data=e.dataTransfer.getData('key');

  }

  HTML5标准中dataTransfer对象可以保存的数据必须有key,key只能叫“text/html”或“text/uri-list”或“Files”;

2、拖放客户端本地图片到网页中显示:

 客户端图片文件为拖放源对象,网页中的元素是拖放目标对象;

 container.ondrop=function(e){

  var f0=e.dataTransfer.files[0];//File对象

  var fr=new FileReader();//读取文件中的内容

  fr.readAsDataURL(0);//把图片作为dataURL来读取

  fr.onload=function(){//文件读取完成

   var img=new Image();//创建Image元素

   img.src=fr.result;//dataURL

   container.appendChild(img);

  }

 }

 HTML5中新增文件读取相关对象:

  File——代表一个文件;FileList——代表一个文件列表;FileReader——用于读取一个文件中的内容;FileWriter——用于向一个文件中写出内容;

3、HTML5新特性——Web Worker:

 ①由于负责渲染/监听的只有一个UI主线程,所有HTML/CSS/JS的执行都在这一个线程内,若页面加载了非常耗时(算法复杂)的JS操作,会阻塞后续的HTMl/CSS/JS渲染和事件监听,所以需要一个类似于创建新线程地方法(JS没有创建新线程的方法):

  var w=new Work('xx.js');

 在当前UI主线程中创建并启动一个新的并发的工作线程该线程耗时操作,可能阻塞,但不会影响UI主线程;

 ②Worker线程的致命问题:不能执行任何DOM操作,不能使用任何DOM或BOM元素——浏览器只允许UI主线程修改DOM树;

 ③让UI主线程给Worker线程传递数据:

  UI主线程:

   var w=new Work('xx.js');

   w.postMessage('data');

  Worker线程:

   onmessage=function(event){

    var data=event.data;

   }

 ④让Worker线程把运算结果传递给UI主线程:

  Worker线程:

   postMessage('data');

  UI主线程:

   var w=new Worker('xx.js');

   w.onmessage=function(event){

    var data=event.data;

   }

 ⑤Worker用于执行耗时的JS任务,在一个独立的线程中,可以避免UI主线程的阻塞问题;

4、HTML5新特性——WebStorage:

 ①Web客户端存储技术:

  Cookie:兼容性好,但操作繁琐,数据长度限制(4KB);

  Flash:大小没有限制,但依赖于Flash环境;

  Web Storage:大小可达8MB,操作简单,但属于HTML5新特性;

  IndexeedDB:大小没有限制,使用JS操作的一种客户端数据库,但操作稍显复杂;

 ②Web Storage新对象之window.sessionStorage:

  会话级存储,其中的数据可以在一次会话中的多个页面中共享——数据存储在浏览器进程内存中;

  sessionStorage.setItem(key,value);

  var value=sessionStorage.getItem(key);

  sessionStorage.removeItem(key);

  sessionStorage.clear();

  sessionStorage.key(i);

  sessionStorage.length;

 ③Web Storage新对象之window.localStorage:

  跨会话级存储(本地存储),其中数据即使再关闭浏览器/电脑,下次仍可以访问——数据存储在文件系统的磁盘文件中;

  localStorage.setItem(key,value);

  var value=localStorage.getItem(key);

  localStorage.removeItem(key);

  localStorage.clear();

  localStorage.key(i);

  localStorage.length;

 ④如果localStorage中的数据发生了改变,所有已打开的当前网站的浏览器窗口,都会触发window.onstorage事件,从而得到本地存储数据已被修改;


复制链接 网友评论 收藏本文 关闭此页
上一条: 对于移动设备来说离线存储简直就是…  下一条: HTML5新特性之WebSocket
夜鹰教程网成立于2008年,目前已经运营了将近 13 年,发布了大量关于 html5/css3/C#/asp.net/java/python/nodejs/mongodb/sql server/android/javascript/mysql/mvc/easyui/vue/echarts原创教程。 我们一直都在坚持的是:认证负责、一丝不苟、以工匠的精神来打磨每一套教程,让读者感受到作者的用心。我们默默投入的时间,确保每一套教程都是一件作品,而不是呆板的文字和视频! 目前我们推出在线辅导班试运营,模式为一对一辅导,教学工具为QQ。我们的辅导学科包括 java 、android原生开发、webapp开发、商城开发、C#和asp.net开发,winform和物联网开发、web前端开发,但不仅限于此。 普通班针对的是国内学员,例如想打好基础的大学生、想转行的有志青年、想深入学习的程序员、想开发软件的初学者或者业余爱好者等。 就业办针对即将毕业上岗的大四学生,或者打算转行的初级开发工程师。 留学生班针对的是在欧美、加拿大、澳洲、日本、韩国、新加坡等地留学的中国学子,目的是让大家熟练地掌握编程技能,按时完成老师布置的作业,并能顺利地通过考试。 详细咨询QQ:1416759661   夜鹰教程网  基于角色的权限管理系统(c-s/b-s)。
  夜鹰教程网  基于nodejs的聊天室开发视频教程
  夜鹰教程网  Git分布式版本管理视频教程
  夜鹰教程网  MVC+EasyUI视频教程
  夜鹰教程网  在线考试系统视频教程
  夜鹰教程网  MongoDB视频教程。
  夜鹰教程网 Canvas视频教程
  夜鹰教程网 报表开发视频教程
  推荐教程/优惠活动

  热门服务/教程目录

  夜鹰教程网  新手必看,详细又全面。
  夜鹰教程网  购买教程  夜鹰教程网  在线支付-方便
  夜鹰教程网  担保交易-快捷安全   夜鹰教程网  闪电发货
  夜鹰教程网  电话和QQ随时可以联系我们。
  夜鹰教程网 不会的功能都可以找我们,按工作量收费。

客服电话:153 9760 0032

购买教程QQ:1416759661  
  热点推荐
什么是css框架
meta标签实现页面的动感效果
CSS半透明滤镜在FIREFOX和IE下面的…
div+css鼠标悬停在div上,div背景色…
纯css下拉菜单特效
div+css的浏览器兼容问题
CSS定义表格线为单一线
CSS滤镜效果收集(全)
列表显示文字和图片垂直居中对齐
在固定位置显示背景图片
网站变换图片的显示方法
在select外面套一个div或span, se…
常用的CSS命名规则
闪字闪字闪字闪字闪字闪字闪字闪字…
css让图片自动适应表格大小
  尊贵服务
夜鹰教程网 承接业务:软件开发 网站开发 网页设计 .Net+C#+VS2008+MSsql+Jquery+ExtJs全套高清完整版视频教程
  最近更新
HTTP协议实现文件断点续传
H5实现断点上传
行内元素和块级元素汇总
H5视频直播技术介绍
border-image详解
你必须知道的HTML5的新特性
html5 js控制音乐播放
HTML+CSS代码规范
css3学习笔记 transition与animat…
css3学习笔记Transform
css3学习笔记2D或3D转换
css3学习笔记文本特效
css3学习笔记颜色和透明度
css3学习笔记二
css3学习笔记一
  工具下载  需要远程协助? 

sql2008视频教程 c#视频教程

VIP服务:如果您的某个功能不会做,可以加我们QQ,给你做DEMO!

JQUERY  Asp.net教程

MVC视频教程  vs2012
.NET+sql开发
手机:15397600032 C#视频教程下载
微信小程序 vue.js高级实例视频教程

教程咨询QQ:1416759661


这篇文章不能解决你的问题?我们还有相关视频教程云课堂 全套前端开发工程师培训课程

微信号:yyjcw10000 QQ:1416759661  远程协助需要加QQ!

业务范围:视频教程|程序开发|在线解答|Demo制作|远程调试| 点击查看相关的视频教程

技术范围:全端开发/前端开发/webapp/web服务/接口开发/单片机/C#/java/node/sql server/mysql/mongodb/android/。 



关于我们 | 购买教程 | 网站建设 | 技术辅导 | 常见问题 | 联系我们 | 友情链接

夜鹰教程网 版权所有 www.yyjcw.com All rights reserved 备案号:蜀ICP备08011740号3