Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >触摸事件 touchstart、touchmove、touchend

触摸事件 touchstart、touchmove、touchend

作者头像
全栈程序员站长
发布于 2022-09-06 11:49:09
发布于 2022-09-06 11:49:09
1.8K02
代码可运行
举报
运行总次数:2
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

目录

触摸事件概述

触摸事件编码

触摸手指个数分析

触摸目标 DOM 元素分析

触摸位置分析


触摸事件概述

1、HTML5 中, PC 端基于鼠标的界面互动主要是单击, 移动端界面交互方式主要是触摸。

2、移动端浏览器触摸事件:

事件名称

描述

是否包含 touches 数组

touchstart

触摸开始,多点触控,后面的手指同样会触发

touchmove

接触点改变,滑动时

touchend

触摸结束,手指离开屏幕时

touchcancel

触摸被取消,当系统停止跟踪触摸的时候触发

3、每个触摸事件都包括了三个触摸列表,每个列表里包含了对应的一系列触摸点(用来实现多点触控):

1)touches:当前位于屏幕上的所有手指的列表。 2)targetTouches:位于当前DOM元素上手指的列表。 3)changedTouches:涉及当前事件手指的列表。

4、每个 Touch 对象包含的属性如下:

clientX:触摸目标在视口中的x坐标。 clientY:触摸目标在视口中的y坐标。 identifier:标识触摸的唯一ID。 pageX:触摸目标在页面中的x坐标。 pageY:触摸目标在页面中的y坐标。 screenX:触摸目标在屏幕中的x坐标。 screenY:触摸目标在屏幕中的y坐标。 target:触摸的DOM节点目标。

触摸事件编码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!-- meta使用viewport以确保页面可自由缩放 -->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>触摸事件</title>
    <!-- 引入 jQuery 库 -->
    <script src="http://apps.bdimg.com/libs/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">
        $(function () {
            //手指触摸屏幕时触发事件
            $('body').on('touchstart', function () {
                $('p').css({'color': '#f00'});
                console.log("用户手指触摸到屏幕...");
            });
            //手指在屏幕上移动时触发
            $('body').on('touchmove', function (even) {
                $('p').css({'color': '#0f0'});
                console.log("用户手指在屏幕上移动...");
            });
            //手指离开屏幕时触发
            $('body').on('touchend', function () {
                $('p').css({'color': '#00f'});
                console.log("用户手离开屏幕...");
            });
        });
    </script>
</head>
<body>
<p>
    工人阶级是我国的领导阶级,是全面建成小康社会、坚持和发展中国特色社会主义的...<br>
    在中国工会第十七次全国代表大会即将召开之际,让我...<br>
    工人阶级是我们党最坚实最可靠的阶级基础...<br>
    我国工人阶级是我们党最坚实最可靠的阶级基础。我国工人阶级从来都具有走在...<br>
    工人阶级和广大劳动群众始终是推动我国经济社会发展、维护社会安定团结的根本...<br>
    改革开放以来,我国工人阶级队伍不断壮大,素质全面提高,结构更加优化,面貌焕然...<br>
</p>
</body>
</html>

1、如果在 PC 上访问,可以使用 Chrome 浏览器的移动响应式设备进行模拟,或者直接在移动设备(如手机)上访问

2、Chrome 浏览器,F12 进入开发者模式,然后点击左上角的第二个按钮进行切换。

3、上面是使用 JQuery 的写法,推荐使用如下所示的 JavaScript 方式,因为在获取回调函数的 事件对象时,JQuery 方式会有问题,JavaScript 则是没有问题的。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!-- meta使用viewport以确保页面可自由缩放 -->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>触摸事件</title>
    <!-- 引入 jQuery 库 -->
    <script src="http://apps.bdimg.com/libs/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">
        /**
         * element.addEventListener(event, function, useCapture):向指定元素添加事件句柄
         * useCapture:true - 事件句柄在捕获阶段执行;false(默认) - 事件句柄在冒泡阶段执行
         */
        document.addEventListener('touchstart', touch, false);
        document.addEventListener('touchmove', touch, false);
        document.addEventListener('touchend', touch, false);
        function touch(event) {
            /**兼用 IE 浏览器*/
            var event = event || window.event;
            var oInp = document.getElementById("inp");
            switch (event.type) {
                case "touchstart":
                    oInp.innerHTML = "Touch started (" + event.touches[0].clientX + "," + event.touches[0].clientY + ")";
                    break;
                case "touchend":
                    oInp.innerHTML = "<br>Touch end (" + event.changedTouches[0].clientX + "," + event.changedTouches[0].clientY + ")";
                    break;
                case "touchmove":
                    oInp.innerHTML = "<br>Touch moved (" + event.touches[0].clientX + "," + event.touches[0].clientY + ")";
                    break;
            }
        }
    </script>
</head>
<body>
<p id="inp">
</p>
</body>
</html>

4、主要就是在绑定事件的部分略有不同,可以参考 HTML DOM addEventListener() 方法

触摸手指个数分析

1、如下所示,将屏幕上触摸的手指个数信息打印出来进行分析。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!-- meta使用viewport以确保页面可自由缩放 -->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style type="text/css" rel="stylesheet">
        .start {
            border: 1px solid red;
            margin-top: 5px;
        }
        .move {
            border: 1px solid green;
            margin-top: 5px;
            overflow: auto;
        }
        .end {
            border: 1px solid blue;
            margin-top: 5px;
        }
    </style>
    <title>触摸事件</title>
    <!-- 引入 jQuery 库 -->
    <script src="http://apps.bdimg.com/libs/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">
        $(function () {
            //$(".move")[0].addEventListener("touchstart", function (event) {
            document.addEventListener("touchstart", function (event) {
                var touchesSize = event.touches.length;
                var targetTouchesSize = event.targetTouches.length;
                var changedTouchesSize = event.changedTouches.length;
                $(".start").append("tSize=" + touchesSize + ",targetTSize=" + targetTouchesSize + ",changedTSize=" + changedTouchesSize + "\r\n");
            });
            //$(".move")[0].addEventListener("touchstart", function (event) {
            document.addEventListener("touchmove", function (event) {
                var touchesSize = event.touches.length;
                var targetTouchesSize = event.targetTouches.length;
                var changedTouchesSize = event.changedTouches.length;
                $(".move").append("tSize=" + touchesSize + ",targetTSize=" + targetTouchesSize + ",changedTSize=" + changedTouchesSize + "\r\n");

            });
            //$(".move")[0].addEventListener("touchstart", function (event) {
            document.addEventListener("touchend", function (event) {
                var touchesSize = event.touches.length;
                var targetTouchesSize = event.targetTouches.length;
                var changedTouchesSize = event.changedTouches.length;
                $(".end").append("tSize=" + touchesSize + ",targetTSize=" + targetTouchesSize + ",changedTSize=" + changedTouchesSize + "\r\n");
            });
        });
    </script>
</head>
<body>
<div class="start">
    <b>touchstart</b>
</div>
<div class="move">
    <b>touchmove</b>
</div>
<div class="end">
    <b>touchend</b>
</div>
</body>
</html>

2、如下所示,左图是 document.addEventListener、右图是 $(“.move”)[0].addEventListener。

3、tSize 是当前位于屏幕上的所有手指的列表个数、targetTSize 是位于当前绑定事件的 DOM 元素上手指的列表个数、changedTSize 是涉及当前事件手指的列表个数。

4、对于各个数据的含义,想必测试之后一目了然,就不再多说了。

触摸目标 DOM 元素分析

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!-- meta使用viewport以确保页面可自由缩放 -->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style type="text/css" rel="stylesheet">
        html, body {
            width: 100%;
            height: 100%;
        }
        .testArea1 {
            width: 100%;
            height: 15%;
            background-color: #1b6d85;
        }
        .testArea2 {
            width: 100%;
            height: 15%;
            background-color: #1b6d85;
        }
        .start {
            border: 1px solid red;
            margin-top: 5px;
        }
        .move {
            border: 1px solid green;
            margin-top: 5px;
            overflow: auto;
        }
        .end {
            border: 1px solid blue;
            margin-top: 5px;
        }
    </style>
    <title>触摸事件</title>
    <!-- 引入 jQuery 库 -->
    <script src="http://apps.bdimg.com/libs/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">
        /**阻止浏览器默认右键点击事件*/
        $(document).bind("contextmenu", function () {
            console.log("用户点击鼠标右键....." + new Date().getTime());
            return false;
        });
        $(function () {
           /**注意调用的方法不要加括号()*/
            $(".testArea1")[0].addEventListener("touchstart", touchstartFun);
            $(".testArea1")[0].addEventListener("touchmove", touchmoveFun);
            $(".testArea1")[0].addEventListener("touchend", touchendFun);

            $(".testArea2")[0].addEventListener("touchstart", touchstartFun);
            $(".testArea2")[0].addEventListener("touchmove", touchmoveFun);
            $(".testArea2")[0].addEventListener("touchend", touchendFun);
        });
        /**
         * 手指触摸屏幕时——函数调用
         * @param event
         */
        function touchstartFun(event) {
            /**event.targetTouches[0]:表示获取发生在当前 DOM 元素第一个手指对象
             * target:手指触摸的 DOM节点,对原生 JS 不熟悉时,使用 $()转为 JQuery 对象操作
             * */
            console.log("start——" + event.targetTouches[0].target.innerHTML);//js获取触摸DOM对象的文本值
            console.log("start——" + $(event.targetTouches[0].target).attr("class"));//JQuery 获取触摸对象的class属性值
        }
        /**
         * 手指在触摸屏上移动时——函数调用
         * @param event
         */
        function touchmoveFun(event) {
            /**event.targetTouches[0]:表示获取发生在当前 DOM 元素第一个手指对象
             * target:手指触摸的 DOM节点,对原生 JS 不熟悉时,使用 $()转为 JQuery 对象操作
             * */
            console.log("move——" + event.targetTouches[0].target.innerHTML);//js获取触摸DOM对象的文本值
            console.log("move——" + $(event.targetTouches[0].target).attr("class"));//JQuery 获取触摸对象的class属性值
        }
        /**
         * 手指离开屏幕时——函数调用
         * @param event
         */
        function touchendFun(event) {
            /**event.changedTouches[0]:表示获取当前 DOM 元素发生此事件的第一个手指对象
             * target:手指触摸的 DOM节点,对原生 JS 不熟悉时,使用 $()转为 JQuery 对象操作
             *
             * 注意:离开时应该是获取 changedTouches,而不是 targetTouches、touches,因为当手指全部离开屏幕时,它们个数可能为0
             * */
            console.log("end————" + event.changedTouches[0].target.innerHTML);//js 获取触摸 DOM 对象的文本值
            console.log("end————" + $(event.changedTouches[0].target).attr("class"));//JQuery 获取触摸对象的class属性值
        }
    </script>
</head>
<body>
<div class="testArea1">
    触摸测试区域1
</div>
<div class="start">
    <b>touchstart</b>
</div>
<div class="move">
    <b>touchmove</b>
</div>
<div class="end">
    <b>touchend</b>
</div>
<div class="testArea2">
    触摸测试区域2
</div>
</body>
</html>

触摸位置分析

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!-- meta使用viewport以确保页面可自由缩放 -->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style type="text/css" rel="stylesheet">
        html, body {
            width: 100%;
            height: 100%;
        }
        .testArea1 {
            width: 100%;
            height: 15%;
            background-color: #1b6d85;
        }
        .testArea2 {
            width: 100%;
            height: 15%;
            background-color: #1b6d85;
        }
        .start {
            border: 1px solid red;
            margin-top: 5px;
        }
        .move {
            border: 1px solid green;
            margin-top: 5px;
            overflow: auto;
        }
        .end {
            border: 1px solid blue;
            margin-top: 5px;
        }
    </style>
    <title>触摸事件</title>
    <!-- 引入 jQuery 库 -->
    <script src="http://apps.bdimg.com/libs/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">
        /**阻止浏览器默认右键点击事件*/
        $(document).bind("contextmenu", function () {
            console.log("用户点击鼠标右键....." + new Date().getTime());
            return false;
        });
        $(function () {
            /**注意调用的方法不要加括号()*/
            $(".testArea1")[0].addEventListener("touchstart", touchstartFun);
            $(".testArea1")[0].addEventListener("touchmove", touchmoveFun);
            $(".testArea1")[0].addEventListener("touchend", touchendFun);

            $(".testArea2")[0].addEventListener("touchstart", touchstartFun);
            $(".testArea2")[0].addEventListener("touchmove", touchmoveFun);
            $(".testArea2")[0].addEventListener("touchend", touchendFun);
        });
        /**
         * 手指触摸屏幕时——函数调用
         * @param event
         */
        function touchstartFun(event) {
            /**event.targetTouches[0]:表示获取发生在当前 DOM 元素第一个手指对象
             * target:手指触摸的 DOM节点,对原生 JS 不熟悉时,使用 $()转为 JQuery 对象操作
             * */
            var lentgX = event.targetTouches[0].clientX;
            var lentgY = event.targetTouches[0].clientY;
            $(".start").append("<br>" + lentgX + "——" + lentgY);
        }
        /**
         * 手指在触摸屏上移动时——函数调用
         * @param event
         */
        function touchmoveFun(event) {
            /**event.targetTouches[0]:表示获取发生在当前 DOM 元素第一个手指对象
             * target:手指触摸的 DOM节点,对原生 JS 不熟悉时,使用 $()转为 JQuery 对象操作
             * */
            var lentgX = event.targetTouches[0].clientX;
            var lentgY = event.targetTouches[0].clientY;
            $(".move").append("<br>" + lentgX + "——" + lentgY);
        }
        /**
         * 手指离开屏幕时——函数调用
         * @param event
         */
        function touchendFun(event) {
            /**event.changedTouches[0]:表示获取当前 DOM 元素发生此事件的第一个手指对象
             * target:手指触摸的 DOM节点,对原生 JS 不熟悉时,使用 $()转为 JQuery 对象操作
             *
             * 注意:离开时应该是获取 changedTouches,而不是 targetTouches、touches,因为当手指全部离开屏幕时,它们个数可能为0
             * */
            var lentgX = event.changedTouches[0].clientX;
            var lentgY = event.changedTouches[0].clientY;
            $(".end").append("<br>" + lentgX + "——" + lentgY);
        }
    </script>
</head>
<body>
<div class="testArea1">
    触摸测试区域1
</div>
<div class="start">
    <b>touchstart</b>
</div>
<div class="move">
    <b>touchmove</b>
</div>
<div class="end">
    <b>touchend</b>
</div>
<div class="testArea2">
    触摸测试区域2
</div>
</body>
</html>

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/150770.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
touchstart,touchmove,touchend触摸事件的小小实践心得
近段时间使用html5开发一个公司内部应用,而触摸事件必然是移动应用中所必须的,刚开始以为移动设备上或许也会支持鼠标事件,原来是不支持的,好在webkit内核的移动浏览器支持touch事件,并且打包成app也毫无压力。原本以为touch事件应该跟鼠标事件是一样的道理,实践过程中虽然不难,但还是碰到了不少坑,才发现还是略有区别的。
全栈程序员站长
2022/07/18
6840
javaScript — touch事件详解(touchstart、touchmove和touchend)
HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享。今天为大家介绍的事件主要是触摸事件:touchstart、touchmove和touchend。
全栈程序员站长
2022/07/25
2.1K0
移动端前端常见的触摸相关事件touch、tap、swipe等整理
前端的很多事件在PC端和浏览器端可公用,但有些事件却只在移动端产生,如触摸相关的事件
书童小二
2018/09/03
2.6K0
移动端前端常见的触摸相关事件touch、tap、swipe等整理
HTML5移动端开发的常用触摸事件
HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享。今天为大家介绍的事件主要是触摸事件:touchstart、touchmove和touchend。
全栈程序员站长
2022/08/31
1.7K0
vue.js项目中用原生js实现移动端的轮播图
今天我在vue.js项目实战开发过程中遇到了实现轮播图效果的问题,因为不想因为一个轮播图而引用整个jquery,而且我还发现自己根本就不清楚移动端的一些事件,所以我就进行了一些资料查找,并最终解决了这个问题,接下来跟大家分享一下我的解决问题的过程.
@零一
2021/01/29
9.2K0
vue.js项目中用原生js实现移动端的轮播图
移动端触屏事件
移动端浏览器兼容性较好,我们不需要考虑以前 JS 的兼容性问题,可以放心的使用原生 JS 书写效果,但是移动端也有自己独特的地方。比如触屏事件 touch(也称触摸事件),Android和 IOS 都有。
星辰_大海
2020/10/09
3K0
移动端触屏事件
2016.06 第三周 群问题分享
HTML+CSS 怎么让一个容器里面不管存在2个子元素还是1个子元素都能垂直居中 2016.06.20~2016.06.24 核心内容 弹性布局 参考答案 实例: <!doctype html> <html> <head> <meta charset="UTF-8"> <title>HTML5学堂</title> <link rel="stylesheet" href="reset.css"> <style> .wrap { width: 500px; height: 500px
HTML5学堂
2018/03/13
1K0
2016.06 第三周 群问题分享
JS案例 - 基于vue的移动端长按手势
当时首先想到要做长按事件的时候,我想到的是vue内部的自定义指令,毕竟官网里边有这么一句描述:
xing.org1^
2018/08/02
9.2K2
JS案例 - 基于vue的移动端长按手势
移动端页面如何优雅的适配各种屏幕,包括PC端
开发移动端页面,我们通常都会按照一个固定宽度的设计稿来做,但是实际上的手机屏幕尺寸五花八门,如果不进行适配的话会比较影响使用体验。
街角小林
2022/10/31
2.2K0
移动端页面如何优雅的适配各种屏幕,包括PC端
touch事件,touchEvent对象
随着智能手机普及,有越来越多的手机网页和网页版游戏,手机触摸、移动、旋转等等,多种操作。一般电脑的人机交互靠的是鼠标,而手机用的就是触摸。区别有:
冬夜先生
2021/09/06
1K0
【如果你要学JS XIV】—— 移动端常用事件-移动端touch触摸事件
TouchEvent是一类描述手指在触摸平面 (触摸屏、触摸板等)的状态变化的事件。这类事件用于描述一个或多个触点,使开发者可以检测触点的移动,触点的加和减少,等等 touchstart、touchmove、 touchend 三个事件都会各自有事件对象。
像素人
2023/12/27
6680
【如果你要学JS XIV】—— 移动端常用事件-移动端touch触摸事件
进入移动Web世界
那么问题来了,为什么会有一个默认的viewport呢?我们知道,pc端页面,在移动端查看的时候,由于像素不匹配,但是为了能够给用户展现一个比较完整的页面,因此会虚拟出一个viewport出来,在此viewprot上渲染页面。也就是说,最终目的,是为了排版正确。但是由于一般默认情况下,给出的viewport像素宽对页面来说是不友好、不规范的,因此我们还需要解决一个规范问题。解决方案:在head中加一个meta标签格式如下:<metaname="viewport"content="name=value, name=value">
流眸
2019/09/17
1.1K0
手机网页中手指触摸计算 --JQuery 获取touchstart,touchmove,touchend 坐标
  JQuery写法 ---- 1 //手指开始触摸时,触发事件 2 $("#id").on('touchstart',function(e){ 3 4 var touch = e.originalEvent.targetTouches[0]; //取页面上第一个手指 5 6 var x_ distance = touch.pageX; //获取手指在X轴上距最左边的距离 7 8 }) 三个函数: touchstart --(手指放在页面时触发) touchend --(手指离开页面时触
SpiritLing
2023/01/05
1.3K0
触屏事件
TouchEvent是一类描述手指在触摸平面(触摸屏。触摸板等)的状态变化的事件,这类事件用于描述一个或多个触点,使开发者可以检测触点的移动,触点的增加和减少等等
切图仔
2022/09/08
8300
html5简单拖拽实现自动左右贴边+幸运大转盘
此篇文章主要实现两个功能: 1、点击屏幕下方签到悬浮按钮; 2、弹出幸运大转盘,转盘抽奖签到 效果如图: ​ 在网上找了很多移动端拖拽的js实现方式,大部分都是这一种,html5的touch事件,但是
蓓蕾心晴
2018/04/12
4.3K0
html5简单拖拽实现自动左右贴边+幸运大转盘
移动端 局部dom实现滚动
https://github.com/surmon-china/vue-awesome-swiper/issues/423
念念不忘
2019/07/20
9650
触屏事件
移动端浏览器兼容性较好,我们不需要考虑以前 JS 的兼容性问题,可以放心的使用原生 JS 书写效果,但是移动端也有自己独特的地方。比如触屏事件 touch(也称触摸事件),Android和 IOS 都有。
梨涡浅笑
2022/05/08
7960
触屏事件
第134天:移动web开发的一些总结(二)
width —— 视口宽高 height —— 视口宽高 device-width —— 设备的宽高 device- height —— 设备的宽高 orientation:检查设备处于横向(landscape)还是竖屏(portrait)
半指温柔乐
2018/09/11
1.8K0
移动端的touch事件处理
在iPhone 3Gs发布的时候,其自带的移动Safari浏览器就提供了一些与触摸(touch)操作相关的新事件。随后,Android上的浏览器也实现了相同的事件。触摸事件(touch)会在用户手指放在屏幕上面的时候、在屏幕上滑动的时候或者是从屏幕上移开的时候出发。下面具体说明:
周陆军博客
2023/05/07
1.8K0
移动端事件详解
关于移动端事件的一些笔记 移动端事件类型 touchstart事件 touchmove事件 touchend事件 移动端事件对象 touches 屏幕上有几个触点 targetTouches 绑定事件的元素上有几个触点 changedTouches 在屏幕上 改变(位置移动 离开 进入 )的触点的个数(如果手指离开屏幕 只有changedTouched有值 其他都没有) 获取触点坐标 clientX/Y获取的是, 触点相对于可视区的X/Y坐标(不包含滚动)(用的最多) pageX/Y获取的是
一个淡定的打工菜鸟
2018/09/06
1K0
相关推荐
touchstart,touchmove,touchend触摸事件的小小实践心得
更多 >
领券
💥开发者 MCP广场重磅上线!
精选全网热门MCP server,让你的AI更好用 🚀
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验