当前位置:首页 > 日记 > 正文

H5上传本地并预览功能

H5上传本地并预览功能

最近工作中需要H5上传显示图片的功能,如图:

直接上代码:

html部分

<div class="works-wrap">  <div class="figure-box" id="figure_box"></div>  <div class="add-btn">   <input type="file" id="imgUploadBtn" />   <a href="javascript:void(0);" rel="external nofollow" ><i></i>添加作品</a></div>  </div> </div> 

我这边用css将input[type=file] 设置成了opticy:0; 这样可以看起来更像原生的上传。

var addWork = {  add: function(btn, figure_box) {  var figureBox = document.getElementById(figure_box); //获取显示图片的div元素  var input = document.getElementById(btn); //获取选择图片的input元素  //这边是判断本浏览器是否支持这个API。  if (typeof FileReader === 'undefined') {   alert("浏览器版本过低,请先更新您的浏览器~");   input.setAttribute('disabled', 'disabled');  } else {   input.addEventListener('change', readFile, false);  //如果支持就监听改变事件,一旦改变了就运行readFile函数。  }   function readFile() {   var file = this.files[0]; //获取file对象   //判断file的类型是不是图片类型。   if (!/image\/\w+/.test(file.type)) {   alert("请上传一张图片~");   return false;   }    var reader = new FileReader(); //声明一个FileReader实例   reader.readAsDataURL(file); //调用readAsDataURL方法来读取选中的图像文件   //最后在onload事件中,获取到成功读取的文件内容,并以插入一个img节点的方式显示选中的图片   reader.onload = function(e) {   // 创建一个新增的图片和文字input   var figure = $('<div class="figure"><div class="figure-hd">我的头部</div><div class="figure-bd"><img src="' + this.result + '" /><textarea placeholder="请输入文字"></textarea></div></div>');   figure.appendTo(figureBox);   }  }  } } 

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

相关文章

Node.js数据库操作之连接MySQL数据

Node.js数据库操作之连接MySQL数据

数据库操作,数据库,连接,电脑软件,Node,介绍首先说来介绍一下MySQL(非广告)。MySQL是由瑞典的MySQL AB公司开发,后来被甲骨文公司收购。和Oracle一样,MySQL是一个典型的关系型数据库,在百度百科中,把MySQL称为是最好的关系数据库管理系统的之一。…

jquery.uploadifive插件怎么解决上

jquery.uploadifive插件怎么解决上

上传,文件大小,插件,电脑软件,jquery,jQuery.uploadifive插件可以很好的解决上传限制图片或文件大小问题,具体方法如下所示:插件是可以用 但遇到问题如何提示是否超过限制呢没办法研究插件js 发现网上给的提示这个插件里竟然没有没有没有.…

excel表格打印缩小放在一张纸的教

excel表格打印缩小放在一张纸的教

缩小,教程,放在,一张纸,表格,  在Excel中录入的数据过多导致一张纸打印不完,但是放到第二张纸又觉得浪费,这个时候就需要我们进行缩小打印,具体该如何设置缩小打印呢?下面是由小编分享的excel表格打印缩小放在一张纸的教程,以供大家阅读和学…

Excel中2010版进行设置顶端标题行

Excel中2010版进行设置顶端标题行

设置,操作技巧,标题,操作步骤,电脑软件,  在excel录入较多的数据时,我们希望每一页都有标题行,这样就可以清楚的知道我们所要表达的意思了。今天,小编就教大家在Excel中2010版进行设置顶端标题行的操作技巧。Excel中2010版进行设置顶端标题…

jQuery实现table中两列CheckBox只

jQuery实现table中两列CheckBox只

示例,电脑软件,table,jQuery,CheckBox,//html<table id="unit"><tr><th>选项一</th><th>选项二</th><th>姓名</th></tr><tr><td><input type="checkbox" /></td><td><input type="checkbox" /></td><td>小红</td></tr><tr><td><input…

微信小程序本作用域下调用全局JS详

微信小程序本作用域下调用全局JS详

作用域,调用,全局,详解,实例,微信小程序本作用域下调用全局JS详解本地wxml文件<view>app版本:{{version}}</view>本地js文件var app;Page({data:{},onLoad:function() {app = getApp();this.setData({version:app.globalData.appName});}})…

ps怎么设计一个加载的动态小图标?

ps怎么设计一个加载的动态小图标?

加载,小图标,动态,电脑软件,ps,在互联网时代,当网络不好时,看到这样的图片,是不是让你万分抓狂。这里教大家用Photoshop软件制作出动态的加载小图标。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-041、 打…

QQ空间相册批量下载的方法QQ空间相

QQ空间相册批量下载的方法QQ空间相

空间,批量下载,方法,电脑软件,QQ,  QQ空间相册里的照片太多了,一张一张下载比较麻烦,怎么批量下载下来呢?下面小编分享QQ空间相册批量下载的方法,需要的朋友可以参考下.QQ空间相册批量下载的方法1、首先下载一个叫做QQ影像的软件。QQ空间相册…

5种JavaScript脚本加载的方式

5种JavaScript脚本加载的方式

脚本,加载,方式,电脑软件,JavaScript,javaScript文件(下面简称脚本文件)需要被HTML文件引用才能在浏览器中运行。在HTML文件中可以通过不同的方式来引用脚本文件,我们需要关注的是,这些方式的具体实现和这些方式可能会带来的性能问题。当浏览器…

BootStrap框架中的data-[ ]自定义

BootStrap框架中的data-[ ]自定义

自定义属性,推荐,框架,电脑软件,BootStrap,最近几天学习bootstrap有感,通过data-api可以使用所有的bootstrap插件,不用写一行js代码,方便了很多,是我们的首选方式。为什么bootstrap的插件当中出现很多data-api,因为我们通常在使用bootstrap框架…

PPT2007背景怎么设置修改以及更换

PPT2007背景怎么设置修改以及更换

修改,设置,背景,电脑软件,  常常在网上下载了一些PPT模板都不对自己的胃口,想要修改下背景图片,却又不知道从何入手。以下是小编为您带来的关于PPT2007背景设置修改以及更换,希望对您有所帮助。PPT2007背景设置修改以及更换一、PowerPoint中…

ES6新特性一: let和const命令详解

ES6新特性一: let和const命令详解

命令详解,新特性,电脑软件,const,本文实例讲述了ES6新特性中的let和const命令。分享给大家供大家参考,具体如下:1. let 命令① 在js中是没有块级作用域的,var 声明的变量作用域是整个函数体,而let可以起到这一作用{ let a = 1; var b = 2;}co…