1.嵌入H5页面,需要采用web-view标签,如下:

<web-view src="/hybrid/html/index.html" @message="handleMessage"></web-view>

注意:

  • h5页面必须在项目目录:/hybrid/html/下面,因为这样uni-app才不会进行编译
  • @message事件是h5页面向应用发送数据的回调

    2.h5页面代码:

  • <!DOCTYPE html>
    <html lang="zh">
    <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>上传文件</title>
    <style>
    *{
    margin: 0;
    padding: 0;
    }
    .head-btn{
    text-align: center;
    margin-top: 50px;
    }
    .file {
    position: relative;
    display: inline-block;
    background: #D0EEFF;
    border: 1px solid #99D3F5;
    border-radius: 10px;
    padding: 24px 50px;
    overflow: hidden;
    color: #1E88C7;
    text-decoration: none;
    text-indent: 0;
    line-height: 20px;
    font-size: 40px;
    }
    .file input {
    position: absolute;
    font-size: 200px;
    right: 0;
    top: 0;
    opacity: 0;

    }
    .file:hover {
    background: #AADFFD;
    border-color: #78C3F3;
    color: #004974;
    text-decoration: none;
    }
    .determine{
    color: #FFFFFF;
    background-color: #007AFF;
    display: inline-block;
    font-size: 20px;
    border-radius: 5px;
    padding: 8px 24px;
    }
    .showFileName{
    display: inline-block;
    height: 30px;
    min-width: 300px;
    }
    .btn {
    display: block;
    margin: 20px auto;
    padding: 5px;
    background-color: #007aff;
    border: 0;
    color: #ffffff;
    height: 40px;
    width: 200px;
    border-radius: 5px;
    }
    .btn1 {
    display: block;
    margin: 20px auto;
    padding: 5px;
    background-color: #007aff;
    border: 0;
    color: #ffffff;
    height: 40px;
    width: 200px;
    border-radius: 5px;
    }

    .btn-red {
    background-color: #dd524d;
    }

    .btn-yellow {
    background-color: #f0ad4e;
    }

    .desc {
    padding: 10px;
    color: #999999;
    }
    .text{
    background-color: #007AFF;
    text-align: center;
    font-size: 18px;
    color: white;
    height: 45px;
    }
    .text-in{
    padding-top: 10px;
    }
    .body{
    background-image: url(../../static/timg.jpg);
    }

    </style>
    </head>
    <body class="body">
    <div class="text">
    <div class="text-in">
    文件上传
    </div>
    </div>
    <div class="head-btn">
    <form action="" method="post">
    <a href="javascript:;" class="file">选择文件
    <input type="file" name="uploadFile" id="uploadFile" >
    </a>
    </form>
    <p class="showFileName"></p>

    </div>
    <div>
    <button class="btn" type="button" data-action="redirectTo">确定</button>
    <button class="btn1" type="button" data-action="navigateBack">取消上传</button>
    </div>

    <script src="./js/jQuery1_10_2.js"></script>
    <script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>
    <script>
    console.log("转检编号:"+getQuery('id')); //转检编号
    //取url中的参数值
    function getQuery(id) {
    // 正则:[找寻'&' + 'url参数名字' = '值' + '&']('&'可以不存在)
    let reg = new RegExp("(^|&)"+ id +"=([^&]*)(&|$)");
    let r = window.location.search.substr(1).match(reg);
    //console.log("r="+r);
    if(r != null) {
    // 对参数值进行解码
    return decodeURIComponent(r[2]);
    }
    return null;
    }

    $(".file").on("change", "input[type='file']", function() {
    let filePath = $(this).val();
    // console.log(filePath);
    localStorage.setItem("fileAddress", filePath);
    let lastname = localStorage.getItem("fileAddress");
    if (lastname != "") {
    $(".showFileName").html(lastname);
    } else {
    $(".showFileName").html("");
    }
    });
    $('.btn').click(function(evt) {
    var fileUrl;
    var formdata = new FormData(); // 创建一个form类型的数据
    formdata.append("files",$("#uploadFile")[0].files[0]); // 获取上传文件的数据
    formdata.append("operate","UpLoadFile"); // 操作码
    formdata.append("name","name");
    //console.log("files:"+formdata.get("files") + ",name:" + formdata.get("name"))
    console.log("begin")
    $.ajax({
    url: 'http://47.97.163.146:8080/Controler.ashx',
    type: "POST",
    async:false, //同步请求,否则内部嵌套的ajax不会运行
    processData: false,
    contentType: false,
    data:formdata,
    dataType:"json",
    success: function(data) {
    //更新数据库添入附件的url
    console.log("data:" + JSON.stringify(data))
    fileUrl = data.url;
    // var formdata1 = new FormData(); // 创建一个form类型的数据
    // formdata1.append("operate","UploadFileZJ"); // 操作码
    // formdata1.append("ID",getQuery('id'));
    // formdata1.append("url",fileUrl);
    console.log("url地址:"+fileUrl);
    console.log("转检编号:"+getQuery('id'));
    //console.log("url:"+formdata1.get("url") + ",ID:" + formdata1.get("ID")) //查看url和转检id
    $.ajax({
    url: 'http://47.97.163.146:8080/Controler.ashx',
    type: "POST",
    data:{operate:"UploadFileZJ",ID:getQuery('id'),url:fileUrl},
    dataType:"json",
    success: function(data){
    console.log("更新成功")
    },
    error: function(err) {
    console.log(555)
    console.log("更新失败的");
    }
    })
    console.log("这是请求成功的");
    },
    error: function(err) {

    console.log("这是请求失败的");
    }
    });
    console.log("end")

    var target = evt.target;
    if (target.tagName === 'BUTTON') {
    var action = target.getAttribute('data-action');
    if (action == 'redirectTo') {
    uni.redirectTo({
    url: '/pages/index/index',
    success:function (d) {
    console.log("跳转成功");
    },
    fail:function(e){
    console.log(e);
    },
    });
    }
    }
    });

    //取消文件上传
    $('.btn1').click(function(evt) {
    var target = evt.target;
    if (target.tagName === 'BUTTON') {
    var action = target.getAttribute('data-action');
    if (action == 'navigateBack') {
    uni.navigateBack({
    delta: 1
    });
    }
    }
    });

    </script>
    </body>
    </html>

    样式图:

uni-app实现文件上传(h5方式)的更多相关文章

  1. python_way day21 Django文件上传Form方式提交,原生Ajax提交字符处啊,Django文件上传之原生Ajax方式、jQuery Ajax方式、iframe方式,Django验证码,抽屉示例,

    python_way day21 1.Django文件上传至Form方式 2.原生Ajax文件上传提交表单 使用原生Ajax好处:不依赖jquery,在发送一个很小的文件或者字符串的时候就可以用原生A ...

  2. 表单文件上传编码方式(enctype 属性)

    enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码. 如下: <form action="upload.php" method="post&quo ...

  3. JavaWeb 文件上传 commons_fileupload方式

    import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileUploadExcept ...

  4. type=file文件上传H5新特性

    1.语法 <input name="myFile" type="file"> 2.属性(以下三个仅HTML5支持,因此存在兼容性问题) (1)mul ...

  5. springMVC两种方式实现多文件上传及效率比较

    springMVC实现 多文件上传的方式有两种,一种是我们经常使用的以字节流的方式进行文件上传,另外一种是使用springMVC包装好的解析器进行上传.这两种方式对于实 现多文件上传效率上却有着很大的 ...

  6. Java实现文件上传

    最近自己在做一个小系统玩的时候涉及到了文件的上传,于是在网上找到Java上传文件的方案,最后确定使用common-fileupload实现上传操作. 需求说明 用户添加页面有一个“上传”按钮,点击按钮 ...

  7. java常见3种文件上传速度对比和文件上传方法详细代码

    在java里面文件上传的方式很多,最简单的依然是FileInputStream.FileOutputStream了,在这里我列举3种常见的文件上传方法代码,并比较他们的上传速度(由于代码是在本地测试, ...

  8. servlet3.0文件上传与下载

    描述:文件上传与下载是在JavaEE中常见的功能,实现文件上传与下载的方式有多种,其中文件上传的方式有: (1)commons-fileupload: (2)Servlet 3.0 实现文件上传 (3 ...

  9. Selenium2学习-039-WebUI自动化实战实例-文件上传下载

    通常在 WebUI 自动化测试过程中必然会涉及到文件上传的自动化测试需求,而开发在进行相应的技术实现是不同的,粗略可划分为两类:input标签类(类型为file)和非input标签类(例如:div.a ...

随机推荐

  1. 美团CodeM 资格赛第一题

    美团外卖的品牌代言人袋鼠先生最近正在进行音乐研究.他有两段音频,每段音频是一个表示音高的序列.现在袋鼠先生想要在第二段音频中找出与第一段音频最相近的部分. 具体地说,就是在第二段音频中找到一个长度和第 ...

  2. C++扬帆远航——9(小学生算数程序)

    /* * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:studentjishu.cpp * 作者:常轩 * 微信公众号 ...

  3. Docker 运行容器 CentOS7 使用systemctl 启动报错 Failed to get D-Bus connection: Operation not permitted

    原系统:Centos 7 Docker 版本:1.12.6 操作:安装并运行 Tomcat 问题:在创建好容器之后,并且进入系统运行启动tomcat [root@cd11558d3a22 /]# sy ...

  4. C# InputStream获取后乱码处理

    Post推送过来的数据流获取后部分中文出现乱码,晚上找了好多办法,不如朋友鼎力相助,哈哈哈~不说废话了上代码把 旧代码基本是网上普遍写法,字段不长用起来不会有乱码情况,但是传送字段一旦过长,超过byt ...

  5. HTTP协议详解(深入理解)

    版权声明:本文为CSDN博主「有抱负的小狮子」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明.原文链接:https://blog.csdn.net/weixin_ ...

  6. Java 读取Word中的脚注、尾注

    本文介绍读取Word中的脚注及尾注的方法,添加脚注.尾注可以参考这篇文章. 注:本文使用了Word类库(Free Spire.Doc for Java 免费版)来读取,获取该类库可通过官网下载,并解压 ...

  7. Eureka在有虚拟网卡的情况下获取正确的IP

    发现问题 最近项目在Eureka注册时,发现一个问题:注册的IP地址不是 192.168.0.XXX 的网络IP,而是另外一个网段的地址,如图 通过 ipconfig 命令查看本机的IP地址发现,该I ...

  8. 分享一次C#调用Delphi编写Dll程序

    1.前言: 最近接手了一个项目需要和Delphi语言编写的一个系统进行一些接口的对接,数据在传输过程中采用Des加密方式,因为Delphi 平台的加密方式和C#平台的加密方式不互通,所以采用的方式是C ...

  9. 认识Nginx

    无论你用浏览器还是APP访问多数网站,到达的第一站就是Nginx. 后来者居上的Nginx 千禧年前后,互联网业务迎来了高速发展,老牌的Web服务器都无法满足高性能.高可靠的市场需求. 一个开源的(遵 ...

  10. Learn Regex The Easy Way

    GitHub上的正则表达式在线学习Learn Regex The Easy Way,可以帮助初学者快速入门 该项目已汉化,可在线练习 地址:https://github.com/ziishaned/l ...