广告位联系
返回顶部
分享到

Ajax实现上传图像功能

Ajax 来源:互联网 作者:秩名 发布时间:2022-04-11 21:30:45 人浏览
摘要

最终效果展示 xhr发起请求 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 7

最终效果展示

xhr发起请求

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

<!DOCTYPE html>

<html lang="en">

  

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" >

    <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>

    <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head>

  

<body>

    <!--1、文件选择框  -->

    <input type="file" id="file1">

    <!-- 2、上传文件的按钮 -->

    <button id="btnupload">上传文件</button>

    <br/>

    <div class="progress" style="width:300px;margin:5px;">

        <div class="progress-bar progress-bar-striped active" style="width: 0%;" id="precent">

            0%

        </div>

    </div>

    <!-- 3、img标签 来显示上传成功以后的图片 -->

    <img alt="" id="img" width="800">

  

    <script>

       var precent = document.querySelector('#precent')

        var btnupload = document.querySelector('#btnupload')

        btnupload.addEventListener('click', function() {

            var files = document.querySelector('#file1').files

            if (files.length <= 0) {

                return alert('请选择要上传的文件')

            }

  

            var fd = new FormData()

            fd.append('avatar', files[0])

            var xhr = new XMLHttpRequest()

  

            xhr.upload.onprogress = function(e) {

                console.log(e);

                if (e.lengthComputable) {

                    var h = Math.ceil((e.loaded / e.total) * 100)

                    precent.style.width = h + '%'

                    precent.innerHTML = h + '%'

                    console.log(h);

                }

            }

            xhr.upload.onload = function() {

                $('#precent').removeClass().addClass('progress-bar progress-bar-success')

            }

  

            xhr.open('post', 'http://www.liulongbin.top:3006/api/upload/avatar')

            xhr.send(fd)

            xhr.onreadystatechange = function() {

                if (xhr.readyState == 4 && xhr.status == 200) {

                    var data = JSON.parse(xhr.responseText)

                    console.log(data);

                    if (data.status == 200) {

                        console.log('上传成功');

                        document.querySelector('#img').src = 'http://www.liulongbin.top:3006' + data.url

                    } else {

                        console.log('上传失败');

                    }

                }

            }

        })

    </script>

</body>

  

</html>

ajax发起请求

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

<!DOCTYPE html>

<html lang="en">

  

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <script src="jquery.js"></script>

    <style>

        img {

            width: 50px;

            height: 50px;

            display: none;

        }

    </style>

</head>

  

<body>

    <input type="file" id="file1">

    <button id="btnupload">上传文件</button>

    </br>

    <img src="5-121204193R5-50.gif" alt="" id="loading">

    <script>

        $(function() {

            $(document).ajaxStart(function() {

                $('#loading').show()

            })

            $(document).ajaxStop(function() {

                $('#loading').hide()

            })

            $('#btnupload').on('click', function() {

                var files = $('#file1')[0].files

                if (files.length <= 0) {

                    alert('请选择文件')

                }

                console.log('ok');

                var fd = new FormData()

                fd.append('avatar', files[0])

                $.ajax({

                    method: 'POST',

                    url: 'http://www.liulongbin.top:3006/api/upload/avatar',

                    data: fd,

                    processData: false,

                    contentType: false,

                    success: function(res) {

                        console.log(res);

                    }

                })

  

            })

  

        })

    </script>

</body>

  

</html>


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/qq_45387575/article/details/124081612
相关文章
  • AJAX原理以及axios、fetch区别

    AJAX原理以及axios、fetch区别
    AJAX原理 Ajax的原理简单来说是在用户和服务器之间加了个中间层(AJAX引擎),通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,
  • Ajax实现上传图像功能

    Ajax实现上传图像功能
    最终效果展示 xhr发起请求 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
  • Ajax的疑难杂症介绍

    Ajax的疑难杂症介绍
    跨域问题 如图所示,这是通过jquery封装的ajax请求了一个本地的php文件(无框架),console提示CORS策略已阻止来自来源的null:请求的资源上不
  • 前端实现滑动按钮AJAX与后端交互的代码

    前端实现滑动按钮AJAX与后端交互的代码
    html代码 1 2 3 4 div class=switch-box input id=switchButton type=checkbox class=switch / label for=switchButton/label /div css代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 1
  • AJAX实现省市县三级联动效果

    AJAX实现省市县三级联动效果
    (tips:其实省市县三级联动只需要引入jQuery省市县三级联动插件就可以实现) 效果图 首先准备两个服务端文件,另一个文件太长,这里就不
  • AJAX实现指定部分页面刷新效果的代码

    AJAX实现指定部分页面刷新效果的代码
    需求:点击左边的选项,不需要整个页面刷新,只进行右边页面的刷新。 这里需要三个文件 work.html !DOCTYPE htmlhtml lang=zh-CNhead meta charset=UTF
  • Ajax实现三级联动的代码

    Ajax实现三级联动的代码
    一、导入数据表和gson.jar 该表包括了中国所有的
  • AJAX实现注册验证用户名的代码
    功能说明 当用户在注册页面输入用户名并且鼠标焦点离开输入框时,到数据表中去验证该用户名是否已经存在,如果存在提示不可用,否则
  • react axios跨域访问一个或多个域名问题的详解
    1.react + axios 跨域访问一个域名 配置非常简单,只需要在当前的 package.json 文件里面配置: proxy:http://iot-demo-web-dev.autel.com, //当然,这里是一
  • $.ajax中contentType: “application/json” 的用法
    具体内容如下所示: $.ajax({ type: httpMethod, cache:false, async:false, contentType: application/json; charset=utf-8, dataType: json,//返回值类型 url: path+url, data:j
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计