前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【原生Ajax】全面了解xhr的概念与使用。

【原生Ajax】全面了解xhr的概念与使用。

作者头像
坚毅的小解同志的前端社区
发布于 2022-11-28 07:21:33
发布于 2022-11-28 07:21:33
2.7K00
代码可运行
举报
文章被收录于专栏:前端领域前端领域
运行总次数:0
代码可运行

✍️ 作者简介: 前端新手学习中。

💂 作者主页: 作者主页查看更多前端教学

🎓 专栏分享:css重难点教学 Node.js教学 从头开始学习 ajax学习

文章目录

XHR的基本使用

  什么是XHR

xhr是浏览器提供的JavaScript对象,通过它,可以请求服务器上的数据资源,之前所学的jquery的ajax函数,就是基于xhr对象封装出来的。

  使用xhr发起GET请求

步骤 1.创建xhr对象 2.使用xhr.open()函数 3.调用xhr.send()函数 4.监听xhr.onreadystatechange事件。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        //创建xhr对象
        let xhr = new XMLHttpRequest();
        //调用open函数
        xhr.open('get', 'http://www.liulongbin.top:3006/api/getbooks')
        //调用send函数
        xhr.send()
        //监听事件
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
                //获取成功
                console.log(xhr.responseText);
            }
        }

  了解xhr对象的readyState属性

XHR对象的readyState属性,用来表示当前Ajax请求所处的状态,每个Ajax请求必然处于一下状态中的一个:

状态

描述

0

UNSENT

XMLHttpRequest对象已被创建,但尚未调用open方法。

1

OPENED

open()方法已经被调用

2

HEADERS_RECEIVED

send()方法已经被调用,响应头也已经接受

3

LOADING

数据接受中,此时response属性中已经包含部分数据

4

DONE

Ajax请求完成,这意味着数据传输已经彻底完成或失败

  使用xhr发起带参数的GET请求

使用xhr对象发起带参数的get请求时,只需在调用xhr.open期间,为URL地址指定参数即可,在地址后面写上?后面以键值对的形式写上数据,多个数据用&连接。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        //创建xhr对象
        let xhr = new XMLHttpRequest();
        //调用open函数
        xhr.open('get', 'http://www.liulongbin.top:3006/api/getbooks?id=1')
        //调用send函数
        xhr.send()
        //监听事件
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
                //获取成功
                console.log(xhr.responseText);
            }
        }

  URL编码与解码

    什么是URL编码

URL地址中,只允许出现英文相关的字母,标点符号,数字,因此。在URL地址中不允许出现中文字符。 如果URL中需要包含中文这样的字符,则必须对中文字符进行编码(转义)。 URL编码的原则,使用安全的字符,(没有特殊用途或者特殊意义的可打印字符)去表示那些不安全的字符。

    如何对URL进行编码与解码

浏览器提供了URL编码与解码的API,分别是:

  • encodeURI() 编码的函数
  • decodeURI()解码的函数
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        let str = '黑马程序员';
        let str2 = encodeURI(str)
        console.log(str2);
        //utf-8一个汉字占三个字节 ,写六个是黑马两个字。
        let str3 = decodeURI('%E9%BB%91%E9%A9%AC')
        let str4 = decodeURI(str2)
        console.log(str3);
        console.log(str4);

  使用xhr发起post请求

步骤 1.创建xhr对象 2.调用xhr.open()函数 3.设置Content-Type属性(固定写法) 4.调用xhr.send()函数。同时指定要发送的数据。 5.监听xhr.onreadystatechange事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        //创建xhr对象
        let xhr = new XMLHttpRequest();
        //调用open()
        xhr.open('post', 'http://www.liulongbin.top:3006/api/addbook');
        //设置Content-Type(固定写法)
        xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');

        //调用send函数
        xhr.send('bookname=水浒传&author=施耐庵&publisher=上海图书出版社')
        //监听事件
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
                console.log(xhr.responseText);
            }
        }

数据交换格式

  什么是数据交换格式

数据交换格式,就是服务器端与客户端之间进行数据传输与交换的格式.

前端领域,经常提及的两种数据交换格式分别是XMLJSON。其中XML用的非常少,所以,我们重点要学习的数据交换格式JSON。

  XML

    什么是XML

xml的英文全称是EXtensible Markup Language,即可扩展标记语言,因此,XML和HTML类似,也是一种标记语言。

    XML和HTML的区别

xml和html虽然都是标记语言,但是,他们两者之间没有任何的关系。

  • HTML被设计用来描述网页上的内容,是网页内容的载体
  • XML被设计用来传输和存储数据,是数据的载体

    XML的缺点

1.XML格式臃肿,和数据无关的代码多,体积大,传输效率低。 2.在JavaScript中解析XML比较麻烦。

  JSON

    什么是JSON

概念:JSON的英文全称是JavaScript Object Notation,即 JavaScript对象表示法。简单来讲,JSON就是JavaScript对象和数组的字符串表示法,它使用文本表示一个JS对象或数组的信息,因此,JSON的本质是字符串。

作用:JSON是一种轻量级的文本数据交换格式,在作用上类似XML,专门用于存储和传输数据,单是JSON比XML更小,更快,更易解析。

现状:JSON是在2001年开始被推广和使用的数据格式,到现今为止,JSON已经成为了主流的数据交换格式。

    JSON的两种结构

JSON就是用字符串来表示JavaScript的对象和数组两种结构,通过这两种结构的相互嵌套,可以表示各种复杂的数据结构

  • 对象结构:对象结构在JSON中表示为{}括起来的内容,数据结构为{key:value,key:value,…}的键值对结构,其中,key必须是使用英文的双引号包裹的字符串,value的数据类型可以是数字,字符串,布尔值,null,数组,对象六种类型。
  • 数组结构:数组结构在JSON中表示为[]括起来的内容,数据结构为[‘java’,‘javascript’,30,true],数组中数据的类型可以是数字,字符串,布尔值,null,数组,对象6种类型。

    JSON语法的注意事项

1.属性名必须使用双引号包裹。 2.字符串类型的值必须使用双引号包裹 3.JSON中不允许使用单引号表示字符串 4.JSON中不能写注释 5.JSON的最外层必须是对象或数组格式。 6.不能使用undefined或函数作为JSON的值

JSON的作用:在计算机与网络之间存储和传输数据。 JSON的本质:用字符串来表示JavaScript对象数据或数组数据。

    JSON和JS对象的关系

JSON是js对象的字符串表示法,它使用文本表示一个js对象的信息,本质是一个字符串。例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var jsobj ={a:'hello',b:'world'}
var jsonstr = '{'a':'hello','b':'world'}'

    JSON和JS对象的互转

要实现从JSON字符串转换为js对象,使用JSON.parse()方法;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        var xhr = new XMLHttpRequest();
        xhr.open('get', 'http://www.liulongbin.top:3006/api/getbooks');
        xhr.send();
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
                console.log(xhr.responseText);
                var restr = JSON.parse(xhr.responseText)
                console.log(restr);
            }
        }

要实现从JS对象转换为JSON字符串,使用JSON.stringify()方法:

    序列化和反序列化

把数据对象转换为字符串的过程,叫做序列化,例如:调用JSON.stringify()函数的操作,叫做JSON序列化。

把字符串转换为数据对象的过程,叫做反序列化,例如:调用JSON.parse()函数的操作,叫做JSON的反序列化。

封装自己的Ajax函数

  要实现的效果

定义一个名为itheima的ajax函数,导入js文件之后,可以进行调用文件内的相关函数。 定义options参数选项 itheima()函数是我们自定义的Ajax函数,它接受一个配置对象作为参数,配置对象中可以配置如下属性:

  • method 请求的类型
  • url 请求的URL地址
  • data 请求携带的数据
  • success 请求成功之后的回调函数

  处理data参数

需要把data对象,转化成查询字符串的格式,从而提交给服务器,因此提前定义resolveData函数如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function resolveData(data) {
    var arr = [];
    for (const k in data) {
        //这里说一下对象的调用方法,对象调用可以使用【】和点,这里的对象调用需要用【】的,k是字符串,点后面不能是字符串,所以不能直接data.k,
        //我们可以先进行字符串链接data.k再使用eval方法进行解析,就可以使用点调用了
        // var str = k + '=' + eval("data." + k);
        var str = k + '=' + data[k];
        arr.push(str);
    }
    return arr.join('&')
}
var str = resolveData({ name: 'xiaoxie', age: 20 });
console.log(str);

  定义itheima函数

在itheima()函数中,需要创建xhr对象,并监听onreadystatechange事件。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function itheima(options) {
    let xhr = new XMLHttpRequest();
    let qs = resolveData(options.data)
--------判断类型 发起请求 代码--------------
    xhr.onreadystatechange = function () {
        if (xhr.readyState === 4 && xhr.status === 200) {
         let result = JSON.parse(xhr.responseText)
            options.success(result)

        }
    }
}

  判断请求的类型

不同的请求类型,对应的xhr对象的不同操作,因此需要对请求类型进行if…else…的判断。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    if (options.method.toUpperCase() === 'GET') {
       xhr.open('get', options.URL + '?' + qs)
        xhr.send();
   } else if (options.method.toUpperCase() === 'POST') {
       xhr.open('post', options.URL)
       xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')
       xhr.send(qs);
   }

xhr level2的新特性

  旧版xhr的缺点

  1. 只支持文本数据的传输,无法用来读取和上传文件。
  2. 传送和接受数据时,没有进度信息,只能提示有没有完成。

  xhr levle2的新特性

  • 可以设置http请求的时限。
  • 可以使用formdata对象管理表单数据
  • 可以上传文件
  • 可以获得数据传输的进度信息。

    设置http请求时限。

有时,Ajax操作很耗时,而且无法预知要花多少时间。如果网速很慢,用户可能要等很久,新版本的xhr对象,增加了timeout属性,可以设置http请求的时限:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
xhr.timeout = 3000

上面的语句,将最长等待时间设为3000毫秒,过了这个时限,就自动停止http请求。与之配套的还有一个timeout事件,用来指定回调函数。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
xhr.ontimeout = function(event){
alert('请求超时')
}
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        let xhr = new XMLHttpRequest();
       xhr.timeout = 30;
       xhr.ontimeout = function () {
           console.log(请求超时);
       }
       xhr.open('get', 'http://liulongbin.top:3006/api/getbooks')
       xhr.send()
       xhr.onreadystatechange = function () {
           if (xhr.readyState === 4 && xhr.status == 200) {
               console.log(xhr.responseText);
           }

       }

    FormData对象管理表单数据

Ajax操作往往用来提交表单数据。为了方便表单处理,HTML5新增了一个FormData对象,可以模拟表单操作。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        let fd = new FormData();
        fd.append('uname', 'xiaoxie')
        fd.append('pwd', 123456)
        let xhr = new XMLHttpRequest();
        xhr.open('post', 'http://www.liulongbin.top:3006/api/formdata')
        xhr.send(fd);
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status == 200) {
                console.log(JSON.parse(xhr.responseText));
            }
        }

FormData对象也可以用来获取网页表单的值,不用通过serialize()方法转换,可以获取值后可以直接使用,不用通过示例代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        var form = document.querySelector('#form1')
        form.addEventListener('submit', function (e) {
            e.preventDefault();

            //创建对象,获取数据。
            let fd = new FormData(form);

            let xhr = new XMLHttpRequest();

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

            xhr.send(fd)
            xhr.onreadystatechange = function () {
                if (xhr.readyState === 4 && xhr.status === 200) {
                    console.log(JSON.parse(xhr.responseText));
                }
            }
        })

    上传文件

新版xhr对象,不仅可以发送文本信息,还可以上传文件。

  1. 定义ui结构
  2. 验证是否选择了文件
  3. 向FormData中追加文件
  4. 使用xhr发起上传文件的请求
  5. 监听onreadystatechange事件 定义UI结构
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    <!-- 文件选择框 -->
    <input type="file" id="file1">
    <!-- 上传文件的按钮 -->
    <button id="btnUpload"></button>
    <br>
    <img src="" alt="" id="img" width="800">

验证是否选择了文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        //获取文件上传按钮
        let btn = document.getElementsByTagName('button')[0];
        //为按钮绑定单击事件处理函数
        btn.addEventListener('click', function () {
            //获取用户选择的文件鼠标
            let files = document.querySelector('#file1').files;

            if (files.length <= 0) {
                return alert('请选择要上传的文件')
            }
            console.log('用户选择了待上传的文件');
        })

向FormData中追加文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 let fd = new FormData()
  fd.append('avatar', files[0])

使用xhr发起上传文件的请求

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
           let xhr = new XMLHttpRequest();
            xhr.open('post', 'http://www.liulongbin.top:3006/api/upload/avatar')
            xhr.send(fd)

监听onreadystatechange事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
            xhr.onreadystatechange = function () {
                if (xhr.readyState === 4 && xhr.status === 200) {
                    let data = JSON.parse(xhr.responseText)
                    if (data.status === 200) {
                        //上传成功
                        alert('上传成功')
                        document.getElementById('img').src = 'http://www.liulongbin.top:3006' + data.url
                    } else {
                        console.log('图片上传失败' + data.message);
                    }
                }
            }

显示文件上传进度

新版本的XHR对象中,可以通过监听xhr.upload.onprogress事件,来获取到文件的上传进度,语法格式如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
            //监听上传进度
            xhr.upload.onprogress = function (e) {
                if (e.lengthComputable) {
                    let uploadProgroess = Math.ceil((e.loaded / e.total) * 100)
                    console.log(uploadProgroess);
                }
            }

美化进度显示

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css"
        integrity="sha384-HSMxcRTRxnN+Bdg0JdbxYKrThecOKuH5zCYotlSAcp1+c8xmyTe9GYg1l9a69psu" crossorigin="anonymous">
 //设置进度条
$('#percent').attr('style', 'width:' + uploadProgroess).html(uploadProgroess + '%')

完整代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!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="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css"
        integrity="sha384-HSMxcRTRxnN+Bdg0JdbxYKrThecOKuH5zCYotlSAcp1+c8xmyTe9GYg1l9a69psu" crossorigin="anonymous">
</head>

<body>
    <!-- 文件选择框 -->
    <input type="file" id="file1">
    <!-- 上传文件的按钮 -->
    <button id="btnUpload">上传文件</button>
    <br>
    <img src="" alt="" id="img" width="800">
    <div class="progress" style="width: 300px;">
        <div class="progress-bar progress-bar-striped active" style="width: 0%" id="percent">
            0%
        </div>
    </div>
    <script>
        //获取文件上传按钮
        let btn = document.getElementsByTagName('button')[0];
        //为按钮绑定单击事件处理函数
        btn.addEventListener('click', function () {
            //获取用户选择的文件属性,是一个数组。
            let files = document.querySelector('#file1').files;
            if (files.length <= 0) {
                return alert('请选择要上传的文件')
            }
            //表单中添加相应的数据
            let fd = new FormData()
            fd.append('tupian', files[0])
            //使用xhr发起上传文件的请求
            let xhr = new XMLHttpRequest();
            //监听上传进度
            xhr.upload.onprogress = function (e) {
                if (e.lengthComputable) {
                    let uploadProgroess = Math.ceil((e.loaded / e.total) * 100)
                    console.log(uploadProgroess);
                    //设置进度条
                    $('#percent').attr('style', 'width:' + uploadProgroess).html(uploadProgroess + '%')
                }
            }
            xhr.open('post', 'http://www.liulongbin.top:3006/api/upload/avatar')
            xhr.send(fd)
            //监听onreadystatechange事件
            xhr.onreadystatechange = function () {
                if (xhr.readyState === 4 && xhr.status === 200) {
                    let data = JSON.parse(xhr.responseText)
                    if (data.status === 200) {
                        //上传成功
                        alert('上传成功')
                        document.getElementById('img').src = 'http://www.liulongbin.top:3006' + data.url
                    } else {
                        console.log('图片上传失败' + data.message);
                    }
                }
            }
        })


    </script>
</body>

</html>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-11-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
“诗歌大模型”在西安城墙激活数字诗词|腾讯探元计划场景共建成果(一)
诗词一直以来都是中华传统文化中一段绚丽的瑰宝,今年春晚西安分会场的“山河诗长安”运用了动画与AR技术,上千名观众与顶流IP“李白”齐诵《将进酒》,传统文化和现代科技的完美融合起来,展示着独属于中国诗词的美和中国人的文化自信。
腾讯研究院
2024/02/28
3980
“诗歌大模型”在西安城墙激活数字诗词|腾讯探元计划场景共建成果(一)
AI大模型,与传统文化到底有什么关系?| 探元计划2023
6月21日,在联合国教科文组织驻华代表处、中国文物信息咨询中心(国家文物局数据中心)、中国文化遗产研究院的指导下,腾讯SSV数字文化实验室与腾讯研究院联合发起“探元计划2023”。
腾讯研究院
2023/11/16
8130
数字文旅周报67期 | “探元计划”2022——探索文化遗产数字活化新纪元创新案例征集正式启动
1、“探元计划”2022——探索文化遗产数字活化新纪元创新案例征集正式启动 为探寻文化遗产数字活化的可持续发展路径,由中国文物保护技术协会指导,腾讯数字文化实验室、腾讯研究院、中国人民大学创意产业技术研究院联合发起,青腾作为特邀共创伙伴的“探元计划”2022——探索文化遗产数字活化新纪元将围绕“前沿科技+文化遗产”领域重大共性关键技术与核心议题方向,面向全社会征集、遴选具有行业前瞻性与社会价值的创新案例、应用场景与解决方案,寻求实现可持续社会价值的共识,共享腾讯优势技术、资源,推动产业共创全真互联的文化遗产
腾讯文旅
2022/05/25
7680
数字文旅周报67期 | “探元计划”2022——探索文化遗产数字活化新纪元创新案例征集正式启动
数字文旅周报92期 | 2023腾讯科技向善创新周T-WEEK开启
01 科技热点 2023腾讯科技向善创新周T-WEEK开启 1月9日,腾讯科技向善创新周T-WEEK 2023开启。据悉,今年的科技向善创新周在线上进行,主题为“生成”。在为期4天的活动中,每一天将有不同的主题演讲、专题论坛,众多知名专家学者、行业资深人士将作为嘉宾参与。  当日,腾讯集团高级副总裁郭凯天在开场致辞中表示,科技向善应该是一家企业内在的人设驱动力,企业必须处理好自身和国家、用户和社会等方方面面的关系,应符合国家发展的方向,符合用户的期望和要求,符合社会不断进步的物质和文化生活需要。  “文博
腾讯文旅
2023/01/10
6060
数字文旅周报92期 | 2023腾讯科技向善创新周T-WEEK开启
数字周报88期|“数字敦煌·开放素材库”正式上线;腾讯宣布将用AI破译甲骨文
行业动态 全球首个基于区块链的数字文化遗产开放共享平台“数字敦煌开放素材库”正式上线 12月8日,在国家文物局“互联网+中华文明”行动计划指导下,敦煌研究院与腾讯公司联合打造的全球首个基于区块链的数字文化遗产开放共享平台“数字敦煌开放素材库”正式上线。6500余份来自敦煌莫高窟等石窟遗址及敦煌藏经洞文献的高清数字资源档案通过素材库向全球开放,为海内外学者、文化爱好者以及艺术创意者打造出“一站式”的敦煌文化共享共创平台,为有效实现文化资源的安全高效流动提供了坚实基础,对确保传统文化传播内容的准确性、推动数字
腾讯文旅
2022/12/13
6390
数字周报88期|“数字敦煌·开放素材库”正式上线;腾讯宣布将用AI破译甲骨文
最新北大报告:文化产业10大关键词、10大特征、10大趋势预测
本报告分为2022年文化产业十大关键词、2022年文化产业十大特征、2023年文化产业趋势预测三个部分,在2023年1月7-8日举行的第二十届中国文化产业新年论坛上对外发布。本报告通过文献检索、大数据分析、专家访谈和问卷调研等方式,征集了全国文化产业界知名专家学者的意见和建议。本报告为“文化产业蓝皮书”《中国文化产业发展报告(2022-2023)》阶段性成果。 01 2022年文化产业十大关键词 1、元宇宙文化产业 在经过2021年元宇宙概念落地和初步普及之后,2022年成为元宇宙相关产业井喷式发展的一年。
腾讯文旅
2023/01/10
7570
最新北大报告:文化产业10大关键词、10大特征、10大趋势预测
数字文旅周报93期 | 全球首发!“数字中轴·小宇宙”游戏科技助力文化遗产
01 产业动态 2022文旅风尚榜榜单隆重揭晓,腾讯文旅荣膺“2022数字文旅标杆企业”大奖 1月13日,由新旅界主办的第二届中国文旅产业创新发展论坛暨2022文旅风尚榜颁奖盛典在上海举行。此次论坛以“破茧·重生”为主题,为业界提供市场创新、产品创新、科技创新以及管理创新方面的有效思路与实操案例。会上,2022文旅风尚榜获奖榜单隆重揭晓,腾讯文旅荣获“2022数字文旅标杆企业”奖项。 全球首发!“数字中轴·小宇宙”游戏科技助力文化遗产 1月13日,由中国古迹遗址保护协会、北京第二外国语学院、山东大学文化
腾讯文旅
2023/01/18
5700
数字文旅周报93期 | 全球首发!“数字中轴·小宇宙”游戏科技助力文化遗产
大咖论道|孙若风:何以长城?从“数字长城”看文化传承的数字化担当
今日中国,历史自觉日益增强,文化自信更加坚定,文化遗产保护传承也迎来重大机遇。要让更多文物和文化遗产活起来,营造传承中华文明的浓厚社会氛围。要积极推进文物保护利用和文化遗产保护传承,挖掘文物和文化遗产的多重价值,传播更多承载中华文化、中国精神的价值符号和文化产品。 数字化是文化遗产保护传承的重要手段。近日,中共中央办公厅、国务院办公厅印发的《关于推进实施国家文化数字化战略的意见》要求,到“十四五”时期末,基本建成文化数字化基础设施和服务平台,形成线上线下融合互动、立体覆盖的文化服务供给体系。到2035年,建
腾讯文旅
2022/06/20
4110
大咖论道|孙若风:何以长城?从“数字长城”看文化传承的数字化担当
全球首个基于区块链的数字文化遗产开放共享平台“数字敦煌开放素材库”正式上线
“数字敦煌开放素材库”正式上线 12月8日,在国家文物局“互联网+中华文明”行动计划指导下,敦煌研究院与腾讯公司联合打造的全球首个基于区块链的数字文化遗产开放共享平台“数字敦煌开放素材库”正式上线。6500余份来自敦煌莫高窟等石窟遗址及敦煌藏经洞文献的高清数字资源档案通过素材库向全球开放,为海内外学者、文化爱好者以及艺术创意者打造出“一站式”的敦煌文化共享共创平台,为有效实现文化资源的安全高效流动提供了坚实基础,对确保传统文化传播内容的准确性、推动数字化资源的确权、扩大文物资源社会开放度、增强敦煌研究院与社
腾讯文旅
2022/12/10
7210
全球首个基于区块链的数字文化遗产开放共享平台“数字敦煌开放素材库”正式上线
数字敦煌 | 中国文化的国际传播还能这么玩?
本文转载自文化产业评论 作者:童清艳(上海交通大学教授、国家哲社重大课题首席专家) 当前,中华优秀传统文化的继承、创新与发展成为我国树立文化自信,提升国家文化软实力的重要举措。数字经济的快速发展,为传统文化的有效开发和利用提供了新的思路。腾讯与敦煌的合作打破了传统文化与流行文化的二元对立,让传统文化真正做到“活起来”。 网络与数字时代,中华文化全球传播内容呈现出“数字化”趋势,网络文学、动漫、游戏、网络符号等数字内容成为中华文化新的话语表达方式,中华文化诸多元素如何被有效开发,传统文化的传承与当代中国
腾讯文旅
2020/06/17
8440
敦煌研究院院长:悉数“敦煌+科技”的N种打开方式
早在 2014 年,习近平总书记就指出:“要坚持古为今用、以古鉴今,坚持有鉴别的对待、有扬弃的继承,而不能搞厚古薄今、以古非今,努力实现传统文化的创造性转化、创新性发展,使之与现实文化相融相通,共同服务以文化人的时代任务。”为我们文化遗产的保护利用指明了方向。 一方面我们要继承和发扬那些代表着优秀中华文化精神的传统文化,另一方面,我们还必须有鉴别地扬弃那些已经不符合时代发展的糟粕。 同时,在传承文化中我们还要坚持“创造性转化和创新性发展”。就是要把传统文化与我们当今的时代有机地结合起来,传承并不是原样
腾讯文旅
2020/06/23
9890
游戏的可能:文化遗产及其保护
8月20日,国产单机游戏《黑神话:悟空》不仅登顶多国游戏榜单,更破圈成为全球文化热潮。其中形神兼备的“文化”意境是最大亮点,主创团队在全国范围内选取了36个景点,游戏中的古建筑、塑像和壁画元素,许多都是游戏主创团队“照扫”而来,对中式美学风格、传统文化元素的应用,对西游精神的当代解读,引发国内玩家情感的高度共鸣,为原本不了解西游的外国友人带去亿点点震撼。
小腾资讯君
2024/08/22
2300
宋可心:腾讯数字文化中国建设的思考与实践
11月21日下午,“2020中国文化计算大会”在北京举行,秉承“跨界·融合·共赢”的主题,邀请文化计算领域的知名学者和科技、文化产业界人士共同研讨、分享了文化计算的最新研究成果和产业转化应用案例。腾讯文旅副总裁宋可心受邀出席大会并发表主旨演讲。以下为演讲实录。 非常高兴受邀参加本次大会。腾讯公司近年来一直致力推动科技+文化创新传承,文旅产业数字化,文旅融合发展等方面的工作,也有了一些实践,相关案例和成果,如何通过科技的手段推动文化产业消费和数字化升级,助力数字文化中国建设,我们有一些思考与大家分享
腾讯文旅
2020/12/01
1.3K0
数字文旅周报91期 | “云游长城”获全球世界遗产教育创新奖;腾讯多个数字版本入藏中国国家版本馆
01 科技热点 “云游长城”获全球世界遗产教育创新奖,被赞具有卓越的跨界示范意义 近日,2022“全球世界遗产教育创新案例奖”国际分享会在线上举行。由腾讯联合中国文物保护基金会等共同打造的“云游长城”项目获得了该奖项的“卓越之星奖”。 “全球世界遗产教育创新案例奖”是由联合国教科文组织亚太地区世界遗产培训与研究中心和联合国教科文组织联系学校网络国际中心联合发起的重磅奖项,其目标为挖掘优秀的遗产教育案例,为全球世界遗产教育创新实践者提供行动的指南和参照系。在全球范围征集的近百个案例中,有10位获得“卓越之星
腾讯文旅
2023/01/04
7310
数字文旅周报91期 | “云游长城”获全球世界遗产教育创新奖;腾讯多个数字版本入藏中国国家版本馆
数字周报80期丨2022中国国际智能产业博览会, 腾讯“科技向善”亮相智博会
1、2022中国国际智能产业博览会丨 腾讯“科技向善”亮相智博会 8月22日,2022中国国际智能产业博览会(简称“智博会”)在重庆正式开幕。 智博会是重庆举办的规格最高、规模最大、影响最广的国际性盛会。本届智博会延续“智能化:为经济赋能,为生活添彩”这一主题,聚焦“智慧城市”年度主题,集中展示大数据智能化发展成果。其中,腾讯展区占地面积308平方米,聚焦“科技向善 共创向前”主题,包含科技、文化&SSV(可持续社会价值创新)两部分,契合新科技、新文创两大业务板块。 传承优秀文化,让历史“活起来”。在
腾讯文旅
2022/08/26
1.1K0
数字周报80期丨2022中国国际智能产业博览会, 腾讯“科技向善”亮相智博会
腾讯捐赠1亿元,用科技破解「文保」难题
受困于文物劣化、修复材料不当、遗址探测技术匮乏等制约,有些文物,不得不被迫封存或面临不可逆损毁,成为当前考古研究与文物保护领域面对的严峻挑战。
小腾资讯君
2025/04/17
1960
我们打算用宇宙射线,给石窟佛像照「CT」
云冈石窟是中国规模最大的古代石窟群之一,是世界文化遗产之一。有 45 个主要洞窟,和51000 多尊大小造像,对研究中国古代艺术、历史和佛教文化有重要价值。
小腾资讯君
2023/12/04
2230
《中国文化产业年度发展报告2020》发布!
近日,由北京大学文化产业研究院和国家文化产业创新与发展研究基地发起,联合国内文化产业领域众多研究者共同编撰的《中国文化产业年度发展报告2020》发布。该《报告》总结了2019年文化产业年度发展情况和相关经验,梳理出了2019年度中国文化产业十大关键词、十大特征以及2020年中国文化产业十大趋势预测。 1月4日-5日,第十七届中国文化产业新年论坛在北京大学举办。论坛由北京大学主办,北京大学艺术学院、北京大学文化产业研究院、中国文化产业管理专业委员会承办,以“新使命:大国文创与文化小康”为主题。本届论坛为
腾讯文旅
2020/06/17
3.4K0
大模型如何赋能传统文化传承发展?我们有10个关键思考
传统文化是一个国家和民族的精神命脉,是文化自信的重要源泉。2024年,党的二十届三中全会明确强调“必须增强文化自信,传承中华优秀传统文化,加快适应信息技术迅猛发展新形势,激发全民族文化创新创造活力。”在全球化和现代化进程中,如何保护、传承和发展中华传统文化成为亟待关注的重要课题。尤其是当前生成式人工智能等新一代信息技术技术迅猛发展,为传统文化的传承与发展带来新的契机。
小腾资讯君
2024/11/07
1640
中国大运河即将上云!腾讯文旅助力打造首个数字化国家文化公园
有着2500多年历史的大运河加速上云步伐。4月23日,腾讯文旅成为“大运河国家文化公园数字云平台”技术支持方,联合江苏省文投集团助力江苏省委省政府打造大运河国家文化公园重点建设区。 在腾讯文旅的助力下,将开展云平台文化数据枢纽、运河知识图谱、区块链版权登记、企业服务平台、云赏运河、运河3D可视化、文化创作工具箱等项目建设,以大运河文化保护传承为引领,助力大运河沿线区域经济社会发展,打造首个数字化国家文化公园。 中国大运河由京杭、隋唐、浙东运河三部分共同组成,全长约3200公里,是世界上开发年代较早、空
腾讯文旅
2021/04/23
9390
推荐阅读
“诗歌大模型”在西安城墙激活数字诗词|腾讯探元计划场景共建成果(一)
3980
AI大模型,与传统文化到底有什么关系?| 探元计划2023
8130
数字文旅周报67期 | “探元计划”2022——探索文化遗产数字活化新纪元创新案例征集正式启动
7680
数字文旅周报92期 | 2023腾讯科技向善创新周T-WEEK开启
6060
数字周报88期|“数字敦煌·开放素材库”正式上线;腾讯宣布将用AI破译甲骨文
6390
最新北大报告:文化产业10大关键词、10大特征、10大趋势预测
7570
数字文旅周报93期 | 全球首发!“数字中轴·小宇宙”游戏科技助力文化遗产
5700
大咖论道|孙若风:何以长城?从“数字长城”看文化传承的数字化担当
4110
全球首个基于区块链的数字文化遗产开放共享平台“数字敦煌开放素材库”正式上线
7210
数字敦煌 | 中国文化的国际传播还能这么玩?
8440
敦煌研究院院长:悉数“敦煌+科技”的N种打开方式
9890
游戏的可能:文化遗产及其保护
2300
宋可心:腾讯数字文化中国建设的思考与实践
1.3K0
数字文旅周报91期 | “云游长城”获全球世界遗产教育创新奖;腾讯多个数字版本入藏中国国家版本馆
7310
数字周报80期丨2022中国国际智能产业博览会, 腾讯“科技向善”亮相智博会
1.1K0
腾讯捐赠1亿元,用科技破解「文保」难题
1960
我们打算用宇宙射线,给石窟佛像照「CT」
2230
《中国文化产业年度发展报告2020》发布!
3.4K0
大模型如何赋能传统文化传承发展?我们有10个关键思考
1640
中国大运河即将上云!腾讯文旅助力打造首个数字化国家文化公园
9390
相关推荐
“诗歌大模型”在西安城墙激活数字诗词|腾讯探元计划场景共建成果(一)
更多 >
LV.1
腾讯云社群运营
目录
  • 文章目录
  • XHR的基本使用
    •   什么是XHR
    •   使用xhr发起GET请求
    •   了解xhr对象的readyState属性
    •   使用xhr发起带参数的GET请求
    •   URL编码与解码
      •     什么是URL编码
      •     如何对URL进行编码与解码
    •   使用xhr发起post请求
  • 数据交换格式
    •   什么是数据交换格式
    •   XML
      •     什么是XML
      •     XML和HTML的区别
      •     XML的缺点
    •   JSON
      •     什么是JSON
      •     JSON的两种结构
      •     JSON语法的注意事项
      •     JSON和JS对象的关系
      •     JSON和JS对象的互转
      •     序列化和反序列化
  • 封装自己的Ajax函数
    •   要实现的效果
    •   处理data参数
    •   定义itheima函数
    •   判断请求的类型
  • xhr level2的新特性
    •   旧版xhr的缺点
    •   xhr levle2的新特性
      •     设置http请求时限。
      •     FormData对象管理表单数据
      •     上传文件
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档