怎么进行网站推广做网站需要搭建服务器么

web/2025/9/27 21:48:20/文章来源:
怎么进行网站推广,做网站需要搭建服务器么,app手机程序开发,网站风格主要包括1.2D转换 转换#xff08;transform#xff09;你可以简单理解为变形 移动#xff1a;translate 旋转#xff1a;rotate 缩放#xff1a;sCale 移动#xff1a;translate 1.移动具体值 /* 移动盒子的位置#xff1a; 定位 盒子的外边距 2d转换移动 */div {width…1.2D转换 转换transform你可以简单理解为变形 移动translate 旋转rotate 缩放sCale 移动translate 1.移动具体值 /* 移动盒子的位置 定位 盒子的外边距 2d转换移动 */div {width: 200px;height: 200px;background-color: pink;/* x就是x轴上移动位置 y 就是y轴上移动位置 中间用逗号分隔*//* transform: translate(x, y); *//* transform: translate(100px, 100px); *//* 1. 我们如果只移动x坐标 *//* transform: translate(100px, 0); *//* transform: translateX(100px); *//* 2. 我们如果只移动y坐标 *//* transform: translate(0, 100px); *//* transform: translateY(100px); */}div:first-child {transform: translate(30px, 30px);}div:last-child {background-color: purple;} 2.移动百分比 div {position: relative;width: 500px;height: 500px;background-color: pink;/* 1. 我们tranlate里面的参数是可以用 % *//* 2. 如果里面的参数是 % 移动的距离是 盒子自身的宽度或者高度来对比的 *//* 这里的 50% 就是 50px 因为盒子的宽度是 100px *//* transform: translateX(50%); */}p {position: absolute;top: 50%;left: 50%;width: 200px;height: 200px;background-color: purple;/* margin-top: -100px;margin-left: -100px; */;/* 盒子往上走自己高度的一半 */transform: translate(-50%, -50%);} 2. 旋转rotate 1.图片旋转 img {width: 150px;/* 顺时针旋转45度 *//* transform: rotate(45deg); */border-radius: 50%;border: 5px solid pink;/* 过渡写到本身上谁做动画给谁加 */transition: all 0.3s;}img:hover {transform: rotate(90deg);}/style/headbodyimg srcmedia/pic.jpg alt/body 2.小三角 div {position: relative;width: 249px;height: 35px;border: 1px solid #000;} div::after {content: ;position: absolute;top: 8px;right: 15px;width: 10px;height: 10px;border-right: 1px solid #000;border-bottom: 1px solid #000;transform: rotate(45deg);transition: all 0.2s;}/* 鼠标经过div 里面的三角旋转 */div:hover::after {transform: rotate(225deg);} 设置旋转中心点 1.语法 transform-origin:xy 2.重点 ·注意后面的参数x和y用空格隔开 ·xy默认转换的中心点是元素的中心点50%50% ·还可以给xy设置像素或者方位名词top bottom left right center div {width: 200px;height: 200px;background-color: pink;margin: 100px auto;transition: all 1s;/* 1.可以跟方位名词 *//* transform-origin: left bottom; *//* 2. 默认的是 50% 50% 等价于 center center *//* 3. 可以是px 像素 *//* transform-origin: 80px 80px; *//* transform-origin: top left; */transform-origin: bottom right ;}div:hover {transform: rotate(360deg);} 案例 div {overflow: hidden;width: 200px;height: 200px;border: 1px solid pink;margin: 10px;float: left;} div::before {content: 小猪佩奇;display: block;width: 100%;height: 100%;background-image: url(./media/pig.jpg); transform: rotate(180deg);transform-origin: left bottom;transition: all 0.4s;}/* 鼠标经过div 里面的before 复原 */div:hover::before {transform: rotate(0deg);}/style/headbodydiv/divdiv/divdiv/div 缩放sCale 1.用法 div {width: 200px;height: 200px;background-color: pink;margin: 100px auto;/* transform-origin: left bottom; */}div:hover {/* 1. 里面写的数字不跟单位 就是倍数的意思 1 就是1倍 2就是 2倍 *//* transform: scale(x, y); *//* transform: scale(2, 2); *//* 2. 修改了宽度为原来的2倍 高度 不变 *//* transform: scale(2, 1); *//* 3. 等比例缩放 同时修改宽度和高度我们有简单的写法 以下是 宽度修改了2倍高度默认和第一个参数一样*//* transform: scale(2); *//* 4. 我们可以进行缩小 小于1 就是缩放 *//* transform: scale(0.5, 0.5); *//* transform: scale(0.5); *//* 5. scale 的优势之处 不会影响其他的盒子 而且可以设置缩放的中心点*//* width: 300px;height: 300px; */transform: scale(2);}/style/headbodydiv/div123123 2.按钮案例 li {float: left;width: 30px;height: 30px;border: 1px solid pink;margin: 10px;text-align: center;line-height: 30px;list-style: none;border-radius: 50%;/* 小手 */cursor: pointer;transition: all .4s;}li:hover {transform: scale(1.2);}/style/headbodyulli1/lili2/lili3/lili4/lili5/lili6/lili7/li/ul 3.综合案例 div {width: 200px;height: 200px;background-color: pink;transition: all .5s;}div:hover {/* transform: rotate(180deg) translate(150px, 50px); *//* 我们同时有位移和其他属性我们需要把位移放到最前面 */transform: translate(150px, 50px) rotate(180deg) scale(1.2);} 二动画 制作动画分为两步 1.先定义动画 2.再使用调用动画 1.用keyframes定义动画类似定义类选择器 keyframes 动画名称{ 0%{ width100px } 100%{ width200px } } 2.元素使用动画 div{ width200pxheight200pxbackground-color:aquamargin100px auto /*调用动画*/ animation-name动画名称 /*持续时间*/ animation-duration持续时间} 1.简单的动画 /* 我们想页面一打开一个盒子就从左边走到右边 *//* 1. 定义动画 */keyframes move {/* 开始状态 */0% {transform: translateX(0px);}/* 结束状态 */100% {transform: translateX(1000px);}} div {width: 200px;height: 200px;background-color: pink;/* 2. 调用动画 *//* 动画名称 */animation-name: move;/* 持续时间 */animation-duration: 2s;} 2.动画序列 /* from to 等价于 0% 和 100% *//* keyframes move {from {transform: translate(0, 0);}to {transform: translate(1000px, 0);}} *//* 动画序列 *//* 1. 可以做多个状态的变化 keyframe 关键帧 *//* 2. 里面的百分比要是整数 *//* 3. 里面的百分比就是 总的时间我们这个案例10s的划分 25% * 10 2.5s */keyframes move {0% {transform: translate(0, 0);}25% {transform: translate(1000px, 0)}50% {transform: translate(1000px, 500px);}75% {transform: translate(0, 500px);}100% {transform: translate(0, 0);}}div {width: 100px;height: 100px;background-color: pink;animation-name: move;animation-duration: 10s;} 3.动画属性 属性          描述 keyframes 规定动画 animation 所有动画属性的简写属性 animation-name 规定keyframes动画的名称必须的 animation-duration 规定动画完成一个周期花费的秒或毫秒默认是0。必须的 aniamtion-timing-function 规定动画的速度曲线默认是‘ease’ animation-delay 规定动画何时开始,默认是0 animation-iteration-count 规定动画被播放的次数默认是1还有infinite animation-direction 规定动画是否在下一周期逆向播放默认是‘normal’,alternate逆向播放 animation-play-state 规定动画是否正在运行或暂停默认是’running’,还有‘pause’ animation-fill-mode 规定动画结束后状态保持forwards,回到起始backwards 1.基本使用 keyframes move {0% {transform: translate(0, 0);}100% {transform: translate(1000px, 0);}}div {width: 100px;height: 100px;background-color: pink;/* 动画名称 */animation-name: move;/* 持续时间 */animation-duration: 2s;/* 运动曲线 *//* animation-timing-function: ease; *//* 何时开始 */animation-delay: 2s;/* 重复次数 iteration 重复的 conut 次数 infinite 无限 *//* animation-iteration-count: infinite; *//* 是否反方向播放 默认的是 normal 如果想要反方向 就写 alternate *//* animation-direction: alternate; *//* 动画结束后的状态 默认的是 backwards 回到起始状态 我们可以让他停留在结束状态 forwards *//* animation-fill-mode: forwards; *//* animation: name duration timing-function delay iteration-count direction fill-mode; *//* animation: move 2s linear 0s 1 alternate forwards; *//* 前面2个属性 name duration 一定要写 *//* animation: move 2s linear alternate forwards; */}div:hover {/* 鼠标经过div 让这个div 停止动画鼠标离开就继续动画 */animation-play-state: paused;} 2.大数据热图 body {background-color: #333;}.map {position: relative;width: 747px;height: 616px;background: url(media/map.png) no-repeat;margin: 0 auto;}.city {position: absolute;top: 227px;right: 193px;color: #fff;}.tb {top: 500px;right: 80px;}.dotted {width: 8px;height: 8px;background-color: #09f;border-radius: 50%;}.city div[class^pulse] {/* 保证我们小波纹在父盒子里面水平垂直居中 放大之后就会中心向四周发散 */position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);width: 8px;height: 8px;box-shadow: 0 0 12px #009dfd;border-radius: 50%;animation: pulse 1.2s linear infinite;}.city div.pulse2 {animation-delay: 0.4s;}.city div.pulse3 {animation-delay: 0.8s;}keyframes pulse {0% {}70% {/* transform: scale(5); 我们不要用scale 因为他会让 阴影变大*/width: 40px;height: 40px;opacity: 1;}100% {width: 70px;height: 70px;opacity: 0;}}/style/headbodydiv classmapdiv classcitydiv classdotted/divdiv classpulse1/divdiv classpulse2/divdiv classpulse3/div/divdiv classcity tbdiv classdotted/divdiv classpulse1/divdiv classpulse2/divdiv classpulse3/div/div/div 1文字打印效果 div {overflow: hidden;font-size: 20px;width: 0;height: 30px;background-color: pink;/* 让我们的文字强制一行内显示 */white-space: nowrap;/* steps 就是分几步来完成我们的动画 有了steps 就不要在写 ease 或者linear 了 */animation: w 4s steps(10) forwards;}keyframes w {0% {width: 0;}100% {width: 200px;}}/style/headbodydiv世纪佳缘我在这里等你/div 2.奔跑的熊大 body {background-color: #ccc;}div {position: absolute;width: 200px;height: 100px;background: url(media/bear.png) no-repeat;/* 我们元素可以添加多个动画 用逗号分隔 */animation: bear .6s steps(8) infinite, move 4s forwards;}keyframes bear {0% {background-position: 0 0;}100% {background-position: -1600px 0;}}keyframes move {0% {left: 0;}100% {left: 50%;/* margin-left: -100px; */transform: translateX(-50%);}}/style/headbodydiv/div 三、3D转换 三维坐标系其实就是指立体空间立体空间是由3个轴共同组成的。 ·x轴水平向右注意X右边是正值左边是负值 ·y轴垂直向下注意y下面是正值上面是负值 ·z轴垂直屏幕注意往外面是正值往里面是负值 1.3D位移translate3d(x,y,z) translform:translateX100px仅仅是在x轴上移动 translform:translateY100px仅仅是在Y轴上移动 translform:translateZ100px仅仅是在z轴上移动注意translateZ一般用px单位transform:translate3dxy其中x、y、z分别指要移动的轴的方向的距离 body {/* 透视写到被观察元素的父盒子上面 */perspective: 200px;}div {width: 200px;height: 200px;background-color: pink;/* transform: translateX(100px);transform: translateY(100px); *//* transform: translateX(100px) translateY(100px) translateZ(100px); *//* 1. translateZ 沿着Z轴移动 *//* 2. translateZ 后面的单位我们一般跟px *//* 3. translateZ(100px) 向外移动100px 向我们的眼睛来移动的 *//* 4. 3D移动有简写的方法 *//* transform: translate3d(x,y,z); *//* transform: translate3d(100px, 100px, 100px); *//* 5. xyz是不能省略的如果没有就写0 */transform: translate3d(200px, 100px, 100px);} 透视perspective body {perspective: 600px;/* 透视写到被观擦元素的父盒子上面 */}div {width: 200px;height: 200px;background-color: pink;margin: 100px auto;transform: translateZ(0);}/style/headbodydiv/divdiv/divdiv/div/body 3.3Drotate3d body {perspective: 300px;}img {display: block;margin: 100px auto;transition: all 1s;}img:hover {transform: rotateX(45deg);}/style/headbodyimg srcmedia/pig.jpg altbody {perspective: 500px;}img {display: block;margin: 100px auto;transition: all 1s;}img:hover {/* transform: rotateZ(180deg); *//* transform: rotate3d(x,y,z,deg); *//* transform: rotate3d(1, 0, 0, 45deg); *//* transform: rotate3d(0, 1, 0, 45deg); */transform: rotate3d(1, 1, 0, 45deg);}/style/headbodyimg srcmedia/pig.jpg alt 4.3D呈现transform-style ·控制子元素是否开启三维立体环境。。 ·transform-style:flat子元素不开启3d立体空间默认的 ·transform-style:preserve-3d子元素开启立体空间 ·代码写给父级但是影响的是子盒子 body {perspective: 500px;}.box {position: relative;width: 200px;height: 200px;margin: 100px auto;transition: all 2s;/* 让子元素保持3d立体空间环境 */transform-style: preserve-3d;}.box:hover {transform: rotateY(60deg);}.box div {position: absolute;top: 0;left: 0;width: 100%;height: 100%;background-color: pink;}.box div:last-child {background-color: purple;transform: rotateX(60deg);}/style/headbodydiv classboxdiv/divdiv/div/div 双面反转 1.搭建HTML结构 div classbox div classfront黑马程序员/div div classbackpink老师等你/div /div ·box父盒子里面包含前后两个子盒子 ·box是翻转的盒子front是前面盒子back是后面盒子 body {perspective: 400px;} .box {position: relative;width: 300px;height: 300px;margin: 100px auto;transition: all .4s;/* 让背面的紫色盒子保留立体空间 给父级添加的 */transform-style: preserve-3d;}.box:hover {transform: rotateY(180deg);}.front,.back {position: absolute;top: 0;left: 0;width: 100%;height: 100%;border-radius: 50%;font-size: 30px;color: #fff;text-align: center;line-height: 300px;}.front {background-color: pink;z-index: 1;}.back {background-color: purple;/* 像手机一样 背靠背 旋转 */transform: rotateY(180deg);}/style/headbodydiv classboxdiv classfront黑马程序员/divdiv classbackpink老师这里等你/div/div 旋转导航案例 * {margin: 0;padding: 0;}ul {margin: 100px;}ul li {float: left;margin: 0 5px;width: 120px;height: 35px;list-style: none;/* 一会我们需要给box 旋转 也需要透视 干脆给li加 里面的子盒子都有透视效果 */perspective: 500px;}.box {position: relative;width: 100%;height: 100%;transform-style: preserve-3d;transition: all .4s;}.box:hover {transform: rotateX(90deg);}.front,.bottom {position: absolute;left: 0;top: 0;width: 100%;height: 100%;}.front {background-color: pink;z-index: 1;transform: translateZ(17.5px);}.bottom {background-color: purple;/* 这个x轴一定是负值 *//* 我们如果有移动 或者其他样式必须先写我们的移动 */transform: translateY(17.5px) rotateX(-90deg);}/style/headbodyullidiv classboxdiv classfront黑马程序员/divdiv classbottompink老师等你/div/div/lilidiv classboxdiv classfront黑马程序员/divdiv classbottompink老师等你/div/div/lilidiv classboxdiv classfront黑马程序员/divdiv classbottompink老师等你/div/div/lilidiv classboxdiv classfront黑马程序员/divdiv classbottompink老师等你/div/div/lilidiv classboxdiv classfront黑马程序员/divdiv classbottompink老师等你/div/div/lilidiv classboxdiv classfront黑马程序员/divdiv classbottompink老师等你/div/div/li/ul 旋转木马 body {perspective: 1000px;}section {position: relative;width: 300px;height: 200px;margin: 150px auto;transform-style: preserve-3d;/* 添加动画效果 */animation: rotate 10s linear infinite;background: url(media/pig.jpg) no-repeat;}section:hover {/* 鼠标放入section 停止动画 */animation-play-state: paused;}keyframes rotate {0% {transform: rotateY(0);}100% {transform: rotateY(360deg);}}section div {position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url(media/dog.jpg) no-repeat;}/* 正对着的图片 z轴*/section div:nth-child(1) {transform: rotateY(0) translateZ(300px);}/* 右边的图片 */section div:nth-child(2) {/* 先旋转好了再 移动距离 */transform: rotateY(60deg) translateZ(300px);}section div:nth-child(3) {/* 先旋转好了再 移动距离 */transform: rotateY(120deg) translateZ(300px);}section div:nth-child(4) {/* 先旋转好了再 移动距离 */transform: rotateY(180deg) translateZ(300px);}section div:nth-child(5) {/* 先旋转好了再 移动距离 */transform: rotateY(240deg) translateZ(300px);}section div:nth-child(6) {/* 先旋转好了再 移动距离 */transform: rotateY(300deg) translateZ(300px);}/style/headbodysectiondiv/divdiv/divdiv/divdiv/divdiv/divdiv/div/section 四、浏览器私有前缀 -moz-代表firefox 浏览器私有属性 -ms-代表ie浏览器私有属性 -webkit-代表safari、chrome私有属性 -o-代表Opera私有属性 2.提倡的写法 -moz-border-radius10px -webkit-border-radius10px -o-border-radius10pxborder-radius10px

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/82991.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么提高网站加载速度十大装潢公司上海

添加更多特征会使所有的模型变得更加复杂,从而增大过拟合的可能性。 在添加新特征或处理一般的高位数据集时,最好将特征的数量减少到只包含最有用的那些特征,并删除其余特征,这样会得到泛化能力更好、更简单的模型。 对于如何判…

网站设计找谁做网站建设资料

文章目录 @[TOC]1、 需求及效果1.1 需求1.2 效果2、 思路及SQL语句3、实现折叠明细表4、结语1、 需求及效果 1.1 需求 想要查看U8的审批流程,查看流程在哪个节点或人停留的时间,这个单据整个流程走下来需要的时间。可以更加直观方便的查看审批效率 1.2 效果 采用了SSRS上…

视频网站开发公司有哪些公司邢台哪儿能做网站

当涉及到与1688官方合作的API接口时,以下是一些建议和指导,以帮助您开始编写相关的代码。 了解API接口文档: 在编写与1688官方合作的API接口之前,首先需要了解1688官方提供的API接口文档。您可以在1688开放平台上找到相关的文档…

沈阳网站建设的价格佛山网站建设方案咨询

本文原word格式百度云盘下载地址:综述 2需求 2作者 2系统一览 2Unity3d客户端 2PHP后台 4准备 6XAMPP 6官网 6下载地址 6教程 6ThinkPHP 6官网 7项目所用版本 7下载地址 7快速入门 7完全手册 7步骤 7准备ThinkPHP 7修改MySQL设置信息 8检测是否成功 9扩展&#xff1…

集约化网站建设情况企业网站做备案

【1】基础学习笔记之opencv(1):opencv中facedetect例子浅析 http://www.cnblogs.com/tornadomeet/archive/2012/03/22/2411318.html【2】OpenCV学习笔记(二十七)——基于级联分类器的目标检测objdect http://blog.csdn.net/yang_xian521/arti…

wordpress 网站统计插件查网站流量的网址

我有一个使用MySQL作为后端的Django应用程序。我在原始MySQL记录显示一个值时遇到困难,但Django在Web应用程序中提供了其他内容。例如,我有一个客户端数据表。每条记录中的一个字段称为snailMailInvoice并且是Y / N选项 - 默认值是Y(varchar类型)。-----…

石油网页设计与网站建设深圳燃气公司网上营业厅

文章目录 为什么要有AVL树什么是AVL树AVL树的实现元素的插入平衡因子的更新AVL树的旋转 AVL树的检查完整实现 本篇总结的是AVL树中的全部内容,配有详细的图解过程 为什么要有AVL树 前面对map/multimap/set/multiset进行了简单的介绍,在其文档介绍中发现…

做网站网页的公司行业网站建设的开发方案

PLC_博图系列☞FB&FC 文章目录 PLC_博图系列☞FB&FC背景介绍FB&FC与C 类比博图中定义函数块 (FB)函数 (FC) 关键字: PLC、 西门子、 博图、 FC 、 FB 背景介绍 这是一篇关于PLC编程的文章,特别是关于西门子的博图软件。我并不是专业的P…

企业电子商务网站建设总结wordpress 中文主题网

在现代科技的迅猛发展下,直播系统源码平台被开发搭建出来,为人们的生活方式带来了很大的改变,直播系统源码平台的好友、短视频、直播、社区等功能让很多人越来越热衷于去在平台上刷视频、看直播、分享生活。用户的喜爱也督促了直播系统源码平…

深圳龙华做网站的互联网创业有哪些项目可以做

背景 今天在安装jenkins后,使用java运行war包的时候,提示jdk1.8版本太低,需要提高版本,所以就需要切换jdk版本 解决 在用户变量中,首先更改了JAVA_HOME的地址为17的目录,发现javac的版本改为17了&#x…

华为建站php编程软件

我们知道,继承,组合,重载,重写是java语言的面向对象实现的基本特征。 那么在java内部,究竟是如何实现这些面对对象的基本特征的呢?继承和组合是面向对象中代码复用的主要实现方式,他们可以达到类…

济南做网站公司xywlcnWordPress的手机菜单键

博主18年的互联网软件开发经验,从一名程序员小白逐步成为了一名架构师,我想通过平台将经验分享给大家,因此博主每天会在各个大牛网站点赞量超高的博客等寻找该技术栈的资料结合自己的经验,晚上进行用心精简、整理、总结、定稿&…

商城类网站方案昆山市建设监察大队官方网站

往期回顾 【QT入门】Qt自定义控件与样式设计之自定义QLineEdit实现搜索编辑框-CSDN博客 【QT入门】Qt自定义控件与样式设计之自定义QTabWidget实现tab在左,文本水平的效果-CSDN博客【QT进阶】Qt Web混合编程之CEF、QCefView简单介绍-CSDN博客 【QT进阶】Qt Web混合编…

重庆省建设厅网站网站备案账号是什么

DBSCAN聚类算法学习笔记 一些概念名词 MinPts:聚类在一起的点的最小数目,超过这一阈值才算是一个族群 核心点:邻域内数据点超过MinPts的点 边界点:落在核心点邻域内的点称为边界点 噪声点:既不是核心点也不是边界点的…

站外推广免费网站自己做网站用什么软件下载

前言:使用Unity开发的游戏需要支持泰语本地化,以及解决显示泰语时Unity的bug 目录 1、Text组件显示泰语2、TextMeshPro组件显示泰语 现在很多游戏都需要显示泰语,下面将介绍Unity如何显示泰语,(仅介绍Unity字体方面的设…

编程网站scratch网址建设项目自主验收验收网站

Vue3中reactive和ref对比 数据角度对比原理角度对比使用角度对比 数据角度对比 ref用来定义: 基本类型reactive用来定义: 对象(或数组)类型数据备注:ref也可以定义对象或数组类型数据,它内部会调用reactive转为代理对象. 原理角度对比 ref通过Object.defineProperty()中的ge…

招聘网站建设技术要求衡阳专业的关键词优化终报价

期刊简介: 【出版社】Elsevier 【影响因子】IF(2022):3.0-4.0 【期刊分区】JCR2区,中科院4区 【检索情况】SCIE 在检,正刊 【参考周期】期刊部系统内提交,预计3个月左右录用,走…

律师推广网站排名网站界面设计案例

UnitTest框架 UnitTest参考文章:https://blog.csdn.net/qq_54219272/article/details/123265794 目标(看完UnitTest框架该有的收获) 掌握UnitTest框架的基本使用方法掌握断言(判断实际结果和预期结果是否一致)的使用方…

厦门模板网站建设亦庄网站开发公司

文章主要讲述px4 如何利用vins_fusion里程计数据实现在室内定位功能。 文章基于以下软、硬件展开。 硬件软件机载电脑: Intel NUC系统:Ubuntu 20.04相机: Intel Realsense D435iros:noetic飞控:Pixhawk 2.4.8固件&am…

网站关键词怎么优化排名wordpress 引用 格式

原文地址:http://www.oschina.net/p/spring-oauth-server?fromerrvpTctDBF转载于:https://www.cnblogs.com/longshiyVip/p/5052657.html