【前端HTML】HTML基础

文章目录

  • HTML
  • 标签
    • 标签属性
  • 基本结构
  • 文档声明
  • HTML标准结构
  • HTML基础
    • 排版标签
    • 语义化标签
    • 块级元素与行内元素
    • 文本标签
    • 图片标签
    • 超链接
      • 跳转到指定页面
      • 跳转到文件
      • 跳转到锚点
      • 唤起指定应用
    • 列表
      • 有序列表
      • 无序列表
      • 列表嵌套
      • 自定义列表
    • 表格
      • 基本结构
      • 常用属性
      • 跨行跨列
    • 常用标签
    • 表单
      • 基本结构
      • 常用表单控件
        • 文本输入框
        • 密码输入框
        • 单选框
        • 复选框
        • 隐藏域
        • 提交按钮
        • 重置按钮
        • 普通按钮
        • 文本域
        • 下拉框
        • 禁用表单控件
        • label标签
        • 总体示例
      • 表单总结

HTML

HTML,HyperText Markup Language,超文本标记语言。

标签

标签是HTML的基本组成单位。

标签分为:双标签单标签.

标签名不区分大小写,但是推荐小写

双标签:

<标签名>标签体</标签名>

单标签:

<标签名>

标签属性

用于给标签提供附加属性

可以写在起始标签单标签中。

<标签名 属性名=“属性值”>

天下

有些特殊的属性,没有属性名,只有属性值。

注意点:

1、不同的标签,有不同的属性;也有一些通用属性

2、属性名、属性值不能乱写,是W3C规定好的

3、属性名、属性值,都不区分大小写,但推荐小写

4、标签中不要出现同名属性。

基本结构

想要呈现在网页中的内容写在body标签中。

head标签中的内容不会出现在网页中。

head标签中的title标签可以指定网页的标题。

<html><head><title>网页标题</title></head><body>......</body>
</html>

文档声明

作用:告诉浏览器当前网页的般般

写法: <!DOCTYPE html>

注意:文档声明必须在网页的第一行,且在HTML标签的外侧

HTML标准结构

标准结构如下:

<!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>
</head>
<body></body>
</html>
  • 输入 !,然后回车,可以快速生成标准结构。
  • 在存放代码的文件夹中,存放一个favicon.ico图片,可配置网站图标。

HTML基础

排版标签

标签名标签含义单/双标签
h1~h6标题
p段落
div没有任何意义,用于整体布局
  • h1 最好写一个, h2~h6 能适当多写。
  • h1~h6 不能互相嵌套,例如: h1 标签中最好不要写 h2 标签了。
  • p 标签很特殊!它里面不能有: h1~h6 、 p 、 div 标签

语义化标签

标签默认的效果不重要,语义最重要!

块级元素与行内元素

块级元素:独占一行(排版标签都是块级元素)

行内元素:不独占一行(比如input),其中只能写行内元素,但不能写块级元素。

<body><!-- 块级元素,独占一行 --><marquee>学习</marquee><!-- 行内元素,不独占一行--><input type="text"><!-- 规则1:块级元素中能写行内元素、块级元素(几乎什么都能写)--><div><span>学习1</span><input type="text"><div>学习2</div></div><!-- 规则2:行内元素中能写行内元素,不能写块级元素--><span><span>学习1</span><input type="text"></span></body>

文本标签

用于包裹词汇、短语等。

通常写在排版标签中。

排版标签更宏观(大段文字),文本标签更微观(词汇、短语)。

文本标签通常是行内元素。

blockquote和address是块级元素,其他的是文本标签,都是行内元素。

图片标签

标签名标签语义常用属性单双标签
img图片src:图片路径,具体位置
alt:图片描述
width:图片宽度,像素,200px或200
height:图片高度

示例代码:

<body><img src="./11.PNG" width="100" alt="操作系统">
</body>

像素px是单位

尽量不要同时修改图片的宽和高。

alt属性的作用:

  • 搜索引擎通过alt属性得知图片的内容。
  • 当图片无法展示时,浏览器会呈现alt属性的值。
  • 盲人阅读器会朗读alt属性的值。

src路径:

相对路径和绝对路径

图片格式:jpg、png、bmp、GIF、webp、base64等。

超链接

主要作用:从当前页面进行跳转。

实现功能:

  1. 跳转到指定页面
  2. 跳转到指定文件
  3. 跳转到锚点位置
  4. 唤起指定应用
标签名标签语义常用属性
a超链接href:指定要跳转的具体目标。
target:控制跳转时如何打开页面,常用值如下:
_self:在本窗口打开。
_blank:在新窗口打开。
id:元素的唯一标识,可用于设置锚点。
name:元素的名字,写在a标签中,也能设置锚点。

跳转到指定页面

<body><a href="https://www.jd.com/" target="_blank">去京东</a> <a href="./10块级元素和行内元素.html" target="_self">去看行内元素</a>
</body>

跳转到文件

代码如下:

	<body><!--跳转到文件--><!--浏览器可以直接打开的文件--><a href="./resource/学习.mp4">学习</a><a href="./resource/报名.pdf">报名表</a><a href="./resource/皮卡丘.gif">皮卡丘</a><a href="./resource/风景.jpg">风景</a><!--浏览器不能打开的文件,会自动触发下载--><a href="./resource/资料.zip">内部资料</a><!--强制触发下载--><a href="./resource/学习.mp4" download="学习片段.mp4">下载电影</a></body>

跳转到锚点

锚点:网页中的一个标记点。

使用方式:

  1. 设置锚点

    <!-- 第一种方式:a标签配合name属性 -->
    <a name="test1"></a>
    <!-- 第二种方式:其他标签配合id属性,a以外的其他标签都可以使用id属性-->
    <h2 id="test2">我是一个位置</h2>
    

    注意:

    1. 具有href属性的a标签是超链接,具有name属性的a标签是锚点。
    2. name和id是区分大小写的,且id最好不要用数字开头。
  2. 跳转锚点

    <!-- 跳转到test1锚点-->
    <a href="#test1">去test1锚点</a>
    <!-- 跳到本页面顶部 -->
    <a href="#">回到顶部</a>
    <!-- 跳转到其他页面锚点 -->
    <a href="demo.html#test1">去demo.html页面的test1锚点</a>
    <!-- 刷新本页面 -->
    <a href="">刷新本页面</a>
    <!-- 执行一段js,如果还不知道执行什么,可以留空,javascript:; -->
    <a href="javascript:alert(1);">点我弹窗</a>
    

唤起指定应用

通过a标签,可以唤起设备应用程序。

<!-- 唤起设备拨号 -->
<a href="tel:10010">电话联系</a>
<!-- 唤起设备发送邮件 -->
<a href="mailto:10010@qq.com">邮件联系</a>
<!-- 唤起设备发送短信 -->
<a href="sms:10086">短信联系</a>

列表

有序列表

概念:有顺序或侧重顺序的列表。

<h2>要把大象放冰箱总共分几步</h2>
<ol><li>把冰箱门打开</li><li>把大象放进去</li><li>把冰箱门关上</li>
</ol>

无序列表

概念:无顺序或不侧重顺序的列表。

<h2>我想去的几个城市</h2>
<ul><li>成都</li><li>上海</li><li>西安</li><li>武汉</li>
</ul>

列表嵌套

概念:列表中的某项内容,包含一个列表(注意:嵌套时,请将解构写完整)。

示例如下:

<!--嵌套列表-->
<h2>我想去的几个城市</h2>
<ul><li>成都</li><li><span>上海</span><ul><li>外滩</li><li>杜莎夫人蜡像馆</li><li><a href="https://www.opg.cn">东方明珠</a></li><li>迪士尼</li></ul></li><li>武汉</li><li>西安</li>
</ul>

显示结果:

注意:li标签最好写在 ul ol 中,不要单独使用。

自定义列表

概念:自定义列表,是一个包含术语名称以及术语描述的列表。

一个dl是一个自定义列表,一个dt是一个术语名称,一个dd是一条术语描述。

示例如下:

<!--自定义列表-->
<h2>如何高效的学习?</h2>
<dl><dt>做好笔记</dt><dd>笔记是我们以后复习的一个抓手</dd><dd>笔记可以是电子版,也可以是纸质版</dd><dt>多加练习</dt><dd>只有敲出来的代码,才是自己的</dd><dt>别怕出错</dt><dd>错很正常,改正后并记住,就是经验</dd>
</dl>

显示结果:

表格

基本结构

表格涉及到的标签:

  • table :表格
  • caption :表格标题
  • thead :表格头部
  • tbody :表格主体
  • tfoot :表格注脚
  • tr :每一行
  • thtd :每一个单元格(备注:表格头部中用 th ,表格主体、表格脚注中用: td )

示例:

<body><table border="1"><!--表格标题--><caption>学生信息</caption><!--表格头部--><thead><tr><td>姓名</td><td>性别</td><td>年龄</td><td>民族</td><td>政治面貌</td></tr></thead><!--表格主体--><tbody><tr><td>张三</td><td></td><td>18</td><td>汉族</td><td>团员</td></tr></tbody><!--表格注脚--><tfoot><tr><td></td><td></td><td></td><td></td><td>共计1人</td></tr></tfoot></table>
</body>

结果:

常用属性

注意:

  1. <table>元素的border属性可以控制表格边框,但是border值的大小,不能控制单元格边框的宽度,只能控制表格最外侧边框的宽度,——后期CSS控制。
  2. 默认情况下,每列的宽度,看这一列单元格最长的那个文字。
  3. 给某个thtd设置了宽度或高度后,所在行或列的宽度或高度就确定了。

跨行跨列

  1. rowspan:指定要跨的行数。
  2. colspan:指定要跨的列数。

本节主要是举例来理解跨行跨列的使用。

课程表效果:

代码:

<body><table border="1"><!--表格标题--><caption>课程表</caption><!--表格头部--><thead><tr><th>项目</th><th colspan="5">上课</th><th colspan="2">活动与休息</th></tr></thead><!--表格主体--><tbody><tr><th>星期</th><th>星期一</th><th>星期二</th><th>星期三</th><th>星期四</th><th>星期五</th><th>星期六</th><th>星期日</th></tr><tr><th rowspan="4">上午</th><th>语文</th><th>数学</th><th>英语</th><th>英语</th><th>物理</th><th>数学竞赛</th><th rowspan="4">休息</th></tr><tr><th>语文</th><th>数学</th><th>英语</th><th>英语</th><th>物理</th><th>数学竞赛</th></tr><tr><th>语文</th><th>数学</th><th>英语</th><th>英语</th><th>物理</th><th>数学竞赛</th></tr><tr><th>语文</th><th>数学</th><th>英语</th><th>英语</th><th>物理</th><th>数学竞赛</th></tr><tr><th rowspan="2">下午</th><th>语文</th><th>数学</th><th>英语</th><th>英语</th><th>物理</th><th>数学竞赛</th><th rowspan="2">休息</th></tr><tr><th>语文</th><th>数学</th><th>英语</th><th>英语</th><th>物理</th><th>数学竞赛</th></tr></tbody></table>
</body>

结果示例:

常用标签

标签名标签含义单/双标签
br换行
hr分隔
pre按原文显示
  1. 使用<p>标签来增加文本之间的行间隔,或者使用CSS中的margin属性。
  2. <hr>的语义是分隔。

表单

概念:一个包含交互的区域,用于收集用户提供的数据。

基本结构

标签名常用属性标签语义
formaction:用于指定表单的提交地址,要与后端人员沟通后确定。
target:用于控制表单提交后,如何打开页面,常用值如下:
_self:在本窗口打开。
_blank:在新窗口打开。
method:用于控制表单的提交方式,后续会详细讲解。
表单
inputtype:设置输入框的类型,text表示普通文本。
name:用于指定提交数据的名字,主要用于与后端人员沟通。
输入框
button按钮

示例:

<form action="https://www.baidu.com/s" target="_blank" method="get"><input type="text" name="wd"><button>去百度搜索</button>
</form>

常用表单控件

文本输入框
<input type="text">
  1. name属性:数据名称。
  2. value属性:输入框的默认输入值。
  3. maxlength:输入框最大可输入长度。
密码输入框
<input type="password">
  1. name属性:数据名称。
  2. value属性:输入框的默认输入值,一般不用,无意义。
  3. maxlength:输入框最大可输入长度。
单选框
<input type="radio" name="sex" value="female"><input type="radio" name="sex" value="male">
  1. name 属性:数据的名称,注意:想要单选效果,多个 radio 的 name 属性值要保持一致。
  2. value 属性:提交的数据值。
  3. checked 属性:让该单选按钮默认选中。
复选框
<input type="checkbox" name="hobby" value="smoke">抽烟
<input type="checkbox" name="hobby" value="drink">喝酒
<input type="checkbox" name="hobby" value="perm">烫头
  1. name 属性:数据的名称。
  2. value 属性:提交的数据值。
  3. checked 属性:让该复选框默认选中。
隐藏域
<input type="hidden" name="tag" value="100">

用户不可见的一个输入区域,作用是: 提交表单的时候,携带一些固定的数据。
name 属性:指定数据的名称。
value 属性:指定的是真正提交的数据。

提交按钮
<input type="submit" value="点我提交表单">
<button>点我提交表单</button>
  1. button 标签 type 属性的默认值是 submit 。
  2. button 不要指定 name 属性
  3. input 标签编写的按钮,使用 value 属性指定按钮文字。
重置按钮
<input type="reset" value="点我重置">
<button type="reset">点我重置</button>
  1. button 不要指定 name 属性
  2. input 标签编写的按钮,使用 value 属性指定按钮文字。
普通按钮
<input type="button" value="普通按钮">
<button type="button">普通按钮</button>

普通按钮的 type 值为 button ,若不写 type 值是 submit 会引起表单的提交。

文本域
<textarea name="msg" rows="22" cols="3">我是文本域</textarea>
  1. rows 属性:指定默认显示的行数,会影响文本域的高度。
  2. cols 属性:指定默认显示的列数,会影响文本域的宽度。
  3. 不能编写 type 属性,其他属性,与普通文本输入框一致
下拉框
<select name="from"><option value="黑">黑龙江</option><option value="辽">辽宁</option><option value="吉">吉林</option><option value="粤" selected>广东</option>
</select>
  1. name 属性:指定数据的名称。
  2. option 标签设置 value 属性, 如果没有 value 属性,提交的数据是 option 中间的文字;如果设置了 value 属性,提交的数据就是 value 的值(建议设置 value 属性)
  3. option 标签设置了 selected 属性,表示默认选中。
禁用表单控件

给表单空间的标签设置disabled,可以禁用表单控件。

input 、 textarea 、 button 、 select 、 option 都可以设置 disabled 属性.

label标签

label标签可与表单控件相关联,关联后点击文字,与之对应的表单控件会获取焦点。

两种与 label 关联方式如下:

  • 让 label 标签的 for 属性的值等于表单控件的 id 。

  • 把表单控件套在 label 标签的里面。

总体示例
<!DOCTYPE html>
<html lang="zh"><head><meta charset="UTF-8"><title>18表单-常用表单控件</title></head><body><form action="https://search.JD.com/search"><!--文本框--><label for="zhanghu">账户:</label><input id="zhanghu" type="text" name="account"><br><!--密码框--><label>密码:<input type="password" name="pwd"><br></label><!--单选框-->性别:<input type="radio" name="gender" value="male" id="nan"><label for="nan"></label><label><input type="radio" name="gender" value="famale" checked></label><br>           <!--复选框-->爱好:<input type="checkbox" name="hobby" value="smoke" checked disabled>抽烟<input type="checkbox" name="hobby" value="drink">喝酒<input type="checkbox" name="hobby" value="perm">烫头<br><!-- 文本域 -->其他:<textarea name="other" cols="30" rows="3"></textarea><br><!-- 下拉框 -->籍贯:<select name="place"><option value="">河北</option><option value="" selected>湖北</option><option value="">湖南</option><option value="" disabled>广东</option></select><br><!--隐藏域--><input type="hidden" name="abc" value="123"><br><!-- 确认按钮 第一种 --><!--<button>确认</button>--><!-- 确认按钮 第二种 --><input type="submit" value="确认"><!-- 重置按钮 第一种 --><!-- <button type="reset">重置</button> --><!-- 重置按钮 第二种 --><input type="reset" value="重置"><!-- 普通按钮 第一种 --><!--<button type="button">检测账号是否被注册</button>--><!-- 普通按钮 第二种 --><input type="button" value="检测账号是否被注册"></form></body>
</html>

效果:

表单总结

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

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

相关文章

大创项目推荐 深度学习的视频多目标跟踪实现

文章目录 1 前言2 先上成果3 多目标跟踪的两种方法3.1 方法13.2 方法2 4 Tracking By Detecting的跟踪过程4.1 存在的问题4.2 基于轨迹预测的跟踪方式 5 训练代码6 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于深度学习的视频多目标跟踪实现 …

VirtualBox安装openSUSE-Leap-15.5虚拟机并配置网络

VirtualBox安装openSUSE-Leap-15.5虚拟机并配置网络 适用于在VirtualBox平台上安装openSUSE-Leap-15.5虚拟机。 1. 安装准备 1.1 安装平台 Windows 11 1.2. 软件信息 软件名称软件版本安装路径Oracle VM VirtualBoxVirtualBox-7.0.12-159484D:\softwareopenSUSE-Leapopen…

HarmonyOS 转场动画 ForEach控制

本文 我们继续说组件的专场特效 上文 HarmonyOS 转场动画 我们通过if控制了转场效果 本文 我们通过 ForEach 控制它的加载和删除 这时候就有人会好奇 ForEach 怎么控制删除呢&#xff1f; 很简单 循环次数不同 例如 第一次 10个 第二次 5个 那么后面的五个就相当于删除啦 我们…

python的tabulate包在命令行下输出表格不对齐

用tabulate可以在命令行下输出表格。 from tabulate import tabulate# 定义表头 headers [列1, 列2, 列3]# 每行的内容 rows [] rows.append((张三,数学,英语)) rows.append((李四,信息科技,数学))# 使用 tabulate 函数生成表格 output tabulate(rows, headersheaders, tab…

Android 开发简介

前言 Android 是由 Google 领导的开放手机联盟开发的基于 Linux 的开源移动操作系统。有关一般详细信息&#xff0c;请参阅 Android 主网站。 Android 开发与其他平台的开发有很大不同。因此&#xff0c;在开始针对 Android 编程之前&#xff0c;我们建议您确保熟悉以下关键主…

【Docker】安装 Nacos容器并根据Nginx实现负载均衡

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《Docker实战》。&#x1f3af;&#x1f3af; &…

什么是技术架构?架构和框架之间的区别是什么?怎样去做好架构设计?(一)

什么是技术架构?架构和框架之间的区别是什么?怎样去做好架构设计?(一)。 在软件行业,对于什么是架构,都有很多的争论,每个人都有自己的理解。在不同的书籍上, 不同的作者, 对于架构的定义也不统一, 角度不同, 定义不同。 一、架构是什么 Linux 有架构,MySQL 有架构,J…

漏洞检测和评估【网站子域扫描工具02】

上一篇&#xff1a;爬取目标网站的域名和子域名【网站子域扫描工具01】 在Python中&#xff0c;有一些流行的漏洞扫描库可以对子域进行漏洞扫描和评估&#xff0c;比如Nmap、Sublist3r等。 1.端口扫描 以下是一个简单的示例代码&#xff0c;展示了如何使用Nmap进行基本的端口扫…

由于找不到d3dcompiler_43.dll缺失,无法打开软件的解决方法分享

d3dcompiler43.dll是什么文件&#xff1f;为什么会出现丢失的情况&#xff1f;又该如何解决呢&#xff1f;本文将详细介绍d3dcompiler43.dll的作用和影响&#xff0c;并提供6个有效的解决方法。 一、d3dcompiler43.dll是什么文件&#xff1f; d3dcompiler43.dll是DirectX SDK…

Windows 下使用C#开启蓝牙(未解决的坑)

需求 当程序检测到蓝牙未打开时需要程序自动将W10的蓝牙开启。 资料 Turn on/off Bluetooth radio/adapter from cmd/powershell in Windows 10 - Super User 上的这个连接是通过powershell 开启蓝牙具体代码如下 [CmdletBinding()] Param ([Parameter(Mandatory$true)][V…

MySQL入门篇:事物操作(开启事物,提交事物,回滚事物),事物四大特性(ACID),并发事物问题(脏读,不可重复读,幻读),事物隔离级别

目录 1.事物简介2.事物操作1.查看/设置事物提交方式&#xff08;方式1&#xff09;2.开启事物&#xff08;方式2&#xff09;3.提交事物4.回滚事物 3.事物四大特性(ACID)1.原子性&#xff08;Atomicity)2.一致性&#xff08;Consistency)3.隔离性&#xff08;lsolation)4.持久性…

MyBatisPlus学习笔记四-扩展功能

1、代码生成器 1.1、官方的1 1.3、官方的2-idea插件 1.3、非官方的-idea插件 2、静态工具 先查询&#xff0c;再分组 3、逻辑删除 4、枚举处理器 5、JSON处理器

使用mininet快速入门ONOS路由交换技术与原理

在SDN下路由交换与传统硬件集成方式的路由交换技术有许多相似之处。其中一个比较重要的点是传统交换机中ASIC (Application Specific Integrated Circuit&#xff0c;专用集成电路)决定了其数据平面所支持的功能&#xff0c;而在SDN中&#xff0c;实现了控制面与数据面的分离。…

数组练习 Leetcode 566.重塑矩阵

在 MATLAB 中&#xff0c;有一个非常有用的函数 reshape &#xff0c;它可以将一个 m x n 矩阵重塑为另一个大小不同&#xff08;r x c&#xff09;的新矩阵&#xff0c;但保留其原始数据。 给你一个由二维数组 mat 表示的 m x n 矩阵&#xff0c;以及两个正整数 r 和 c &#…

k8s---ingress对外服务(ingress-controller)

ingress 概念 k8s的对外服务&#xff0c;ingress service作用现在两个方面&#xff1a; 1、集群内部&#xff1a;不断跟踪的变化&#xff0c;更新endpoint中的pod对象&#xff0c;基于pod的ip地址不断变化的一种服务发现机制。 2、集群外部&#xff1a;类似于负载均衡器&a…

进阶Docker3:Dokerfile构建镜像

目录 Dockerfile 构建基础镜像 基本机构 命令&#xff1a; 命令解释&#xff1a; 准备工作 创建镜像 上传镜像 Dockerfile Dockerfile 是一个文本格式的配置文件&#xff0c; 用户可以使用 Dockerfile 来快速创建自定义的镜像&#xff0c;另外&#xff0c;使 用Docke…

Docker 安装 MySQ

Docker 安装 MySQL MySQL 是世界上最受欢迎的开源数据库。凭借其可靠性、易用性和性能&#xff0c;MySQL 已成为 Web 应用程序的数据库优先选择。 1、查看可用的 MySQL 版本 访问 MySQL 镜像库地址&#xff1a;https://hub.docker.com/_/mysql?tabtags 。 可以通过 Sort b…

使用docker部署RStudio容器并结合内网穿透实现公网访问

文章目录 前言1. 安装RStudio Server2. 本地访问3. Linux 安装cpolar4. 配置RStudio server公网访问地址5. 公网远程访问RStudio6. 固定RStudio公网地址 前言 RStudio Server 使你能够在 Linux 服务器上运行你所熟悉和喜爱的 RStudio IDE&#xff0c;并通过 Web 浏览器进行访问…

旅游项目day04

1. JWT有效期 封装用户登录对象&#xff0c; 在指定时间过期 2. 有些接口需要登录&#xff1f;有些不需要登录&#xff1f; 后端如何知道a需要登录&#xff0c;b不需要登录&#xff1f; 注解。 3. 目的地 一个区域下面包含多个目的地 数据库表&#xff1a; 1. 区域表 2.…

交互设计:提升用户动机

之前给大家介绍了交互设计的底层模型——最新版福格行为模型。 模型告诉我们想让用户进行某个行为有3个步骤&#xff0c;第一个步骤是检查有没有&#xff08;合理的&#xff09;行为提示&#xff0c;我把它翻译成能否吸引用户注意&#xff0c;感兴趣的同学可以查看《交互设计之…