javascript头像上传代码实例


Posted in Javascript onSeptember 28, 2019

上传头像:

相关关键词:

ondragover(拖动元素在投放区内移动)

ondrop (元素放在投放区触发但是要去处理浏览器默认事件的影响:ondragenter、ondragover)

dataTransfer(它可以保存一项或多项数据、一种或多数数据类型,通过它来传输被拖动的数据,以便在拖拽结束的时候,对数据进行其他的操作)

<!-- html: -->
<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title>上传头像图片</title>
  <link rel="stylesheet" type="text/css" href="css/index01.css" rel="external nofollow" />
 </head>
 <body>
  <div class="container">
   <h1>拖动外部图片或单击上传图片</h1>
   <div class="main">
    <input type="file" name="file" id="file"/>
    <img src="img/十字架.png" class="btn">
   </div>
  </div>
 </body>
 <script src="js/index01.js"></script>
</html>
/* css样式: */
*{
 margin: 0;
 padding: 0;
}
.container{
 width: 50%;
 margin: 0 auto;
 height: 400px;
 padding: 20px;
 text-align: center;
}
.main{
 width: 200px;
 height: 200px;
 border: 2px dashed #666;
 margin: 20px auto;
 position: relative;
}
.main input{
 width: 100%;
 height: 100%;
 opacity: 0;
 position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%,-50%);
 z-index: 11;
}
.main .btn{
 width: 150px;
 height: 150px;
 cursor: pointer;
 position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%,-50%);
}
/* js */
window.onload = function() {
 // 获取元素
 var file = document.querySelector("#file");
 var addImg = document.querySelector(".btn");
 var main = document.querySelector(".main");
 // 封装上传图片操作
 function upload(img) {
  // 实例化一个图片对象
  var imgFile = new FileReader();
  // 获取图片的路径
  imgFile.readAsDataURL(img);
  imgFile.onload = function(e) {
   // 将上传图标设置为当前图片
   addImg.src = e.target.result;

  }
 }
 /* 1.点击上传图片 */
 file.onchange = function(e) {
  // 获取上传图片里面的信息
  var img = e.target.files[0];
  upload(img);
 }
 /* 2、拖拽上传 */
 main.ondragover = function() {
  return false;
 }
 main.ondrop = function(e) {
  upload(e.dataTransfer.files[0]);
  return false;
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
select、radio表单回显功能实现避免使用jquery载入赋值
Jun 08 Javascript
如何用JavaScript定义一个类
Sep 12 Javascript
流量统计器如何鉴别C#:WebBrowser中伪造referer
Jan 07 Javascript
jQuery实现设置、移除文本框默认值功能
Jan 13 Javascript
js实现图片放大和拖拽特效代码分享
Sep 05 Javascript
全面解析node 表单的图片上传
Nov 21 Javascript
浅谈js-FCC算法Friendly Date Ranges(详解)
Apr 10 Javascript
vue动画打包后失效问题的解决方法
Sep 18 Javascript
JS闭包原理与应用经典示例
Dec 20 Javascript
微信小程序新手教程之启动页的重要性
Mar 03 Javascript
JQuery 实现文件下载的常用方法分析
Oct 29 jQuery
vue2路由方式--嵌套路由实现方法分析
Mar 06 Javascript
解决layui laydate 时间控件一闪而过的问题
Sep 28 #Javascript
JavaScript生成随机验证码代码实例
Sep 28 #Javascript
laydate只显示时分 不显示秒的功能实现方法
Sep 28 #Javascript
layui时间控件选择时间范围的实现方法
Sep 28 #Javascript
layui table 表格上添加日期控件的两种方法
Sep 28 #Javascript
Layui选项卡制作历史浏览记录的方法
Sep 28 #Javascript
Layui带搜索的下拉框的使用以及动态数据绑定方法
Sep 28 #Javascript
You might like
php判断手机访问还是电脑访问示例分享
2014/01/20 PHP
php强大的时间转换函数strtotime
2016/02/18 PHP
php的socket编程详解
2016/11/20 PHP
PHP hex2bin()函数用法讲解
2019/02/25 PHP
jquery文本框中的事件应用以输入邮箱为例
2014/05/06 Javascript
jquery比较简洁的软键盘特效实现方法
2015/03/19 Javascript
JavaScript中的toUTCString()方法使用详解
2015/06/12 Javascript
JavaScript数据库TaffyDB用法实例分析
2015/07/27 Javascript
jQuery实现默认是闭合的FAQ展开效果菜单
2015/09/14 Javascript
jquery获取所有选中的checkbox实现代码
2016/05/26 Javascript
jQuery Ajax使用FormData对象上传文件的方法
2016/09/07 Javascript
JS实现鼠标移上去显示图片或微信二维码
2016/12/14 Javascript
微信小程序page的生命周期和音频播放及监听实例详解
2017/04/07 Javascript
详解vue.js之绑定class和style的示例代码
2017/08/24 Javascript
nodejs基础之多进程实例详解
2018/12/27 NodeJs
JavaScript常见继承模式实例小结
2019/01/11 Javascript
详解Vue中watch对象内属性的方法
2019/02/01 Javascript
浅谈Vue SSR中的Bundle的具有使用
2019/11/21 Javascript
Vue+Element自定义纵向表格表头教程
2020/10/26 Javascript
[01:09:23]KG vs TNC 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
python中self原理实例分析
2015/04/30 Python
用Python编写生成树状结构的文件目录的脚本的教程
2015/05/04 Python
简单学习Python多进程Multiprocessing
2017/08/29 Python
Python实现定时精度可调节的定时器
2018/04/15 Python
Python实现截取PDF文件中的几页代码实例
2019/03/11 Python
Python常见读写文件操作实例总结【文本、json、csv、pdf等】
2019/04/15 Python
Tensorflow实现多GPU并行方式
2020/02/03 Python
Python3合并两个有序数组代码实例
2020/08/11 Python
全球采购的街头服饰和帽子:Urban Excess
2020/10/28 全球购物
国际贸易专业个人求职信范文分享
2013/12/14 职场文书
体育教师自荐信范文
2013/12/16 职场文书
剪枝的学问教学反思
2014/02/07 职场文书
教师作风整改措施思想汇报
2014/10/12 职场文书
2015年工商局个人工作总结
2015/07/23 职场文书
2016年端午节校园广播稿
2015/12/18 职场文书
Python办公自动化之教你用Python批量识别发票并录入到Excel表格中
2021/06/26 Python