CSS3选择器详解 前端开发入门笔记(六)

news2025/1/15 20:39:34

CSS3选择器是一种用于定位HTML元素的方式,它们可以使样式表更加精确地应用到特定的元素。下面是一些常用的CSS3选择器:

  1. 元素选择器(Element Selector):使用元素名称作为选择器,匹配对应名称的所有元素。例如,p选择器匹配所有<p>标签的元素。

  2. 类选择器(Class Selector):使用.符号后跟类名称,匹配具有相同类的元素。例如,.highlight选择器匹配带有class="highlight"属性的元素。

  3. ID选择器(ID Selector):使用#符号后跟ID名称,匹配具有相同ID的元素。例如,#logo选择器匹配id="logo"的元素。

  4. 属性选择器(Attribute Selector):使用方括号[]来选择具有指定属性的元素。例如,[type="submit"]选择器匹配type="submit"的元素。

  5. 后代选择器(Descendant Selector):使用空格分隔两个选择器,匹配第二个选择器的所有后代元素。例如,div p选择器匹配所有位于<div>元素内的<p>元素。

  6. 子元素选择器(Child Selector):使用>符号分隔两个选择器,匹配第二个选择器的直接子元素。例如,ul > li选择器匹配所有直接位于<ul>元素内的<li>元素。

  7. 伪类选择器(Pseudo-class Selector):使用冒号:后跟伪类名称,匹配特定状态或位置的元素。例如,:hover选择器匹配鼠标悬停在元素上的状态。

  8. 伪元素选择器(Pseudo-element Selector):使用双冒号::后跟伪元素名称,匹配文档中的特定部分。例如,::before选择器用于在元素之前插入内容。

  9. 相邻兄弟选择器(Adjacent Sibling Selector):使用+符号分隔两个选择器,匹配紧接在第一个选择器之后的兄弟元素。例如,h1 + p选择器匹配紧接在<h1>元素后的第一个<p>元素。

  10. 通用兄弟选择器(General Sibling Selector):使用~符号分隔两个选择器,匹配在第一个选择器之后的所有兄弟元素。例如,h2 ~ p选择器匹配所有在<h2>元素后的<p>元素。

  11. 属性值选择器(Attribute Value Selector):使用方括号[]中加上特定属性和值的组合,匹配具有特定属性和对应值的元素。例如,[type="text"]选择器匹配type="text"的元素。

  12. 结构性伪类选择器(Structural Pseudo-class Selector):这些选择器基于元素的位置或结构进行选择。例如,:first-child选择器匹配作为其父元素的第一个子元素的元素。

  13. :not()伪类选择器:使用:not()来排除某些元素。例如,div:not(.highlight)选择器匹配所有<div>元素,但不包括具有class="highlight"属性的元素。

  14. :empty伪类选择器:匹配没有任何子节点的空元素。例如,p:empty选择器匹配没有任何内容的<p>元素。

  15. :checked伪类选择器:匹配被选中的表单元素,如复选框或单选按钮。例如,input:checked选择器匹配被选中的输入元素。

这些CSS3选择器提供了更多维度和灵活性,使得开发者可以更精确地选择和样式化HTML元素。您可以根据需要组合使用这些选择器,以实现所需的效果。

选择器的作用

CSS选择器的作用是用来选择一个或多个元素,并对这些元素应用相应的样式。选择器是将CSS和HTML连接起来的关键,它能够定义哪些HTML元素将会使用哪些CSS样式。

选择器主要有以下几种作用:

  1. 精确地匹配目标元素:可以使用不同类型的选择器来精确地匹配目标元素。例如,通过标签选择器可以匹配所有的<p>元素,通过类选择器可以匹配所有指定了特定类名的元素。

  2. 应用样式:选择器可以用来为元素应用样式。例如,可以使用选择器设置元素的背景颜色、文本颜色、字体样式等等。

  3. 提高代码的可读性和维护性:通过选择器,我们可以更好地组织、管理和维护CSS代码。例如,将类似的元素应用相同的样式,或者根据不同的需求将元素分组并进行样式设置,可以提高代码的可读性和可维护性。

  4. 实现响应式布局:通过选择器,我们可以根据不同设备的特点和屏幕大小选择不同的元素,并应用相应的样式,以实现响应式布局。例如,可以使用媒体查询选择器根据不同的屏幕大小选择元素,并为其设置不同的排列方式和样式。

  5. 提高页面性能:选择器对于页面性能也非常重要。优化CSS选择器的使用可以减少浏览器对DOM树的遍历,从而提高页面渲染的速度和性能。

选择器是CSS的重要特性之一,它能够帮助我们更好地控制和样式化HTML元素,实现响应式布局和提高页面性能等目标。

如何使用手册

CSS参考手册的网址:http://css.doyoe.com/

CSS参考手册的下载链接:http://download.csdn.net/download/smyhvae/10243974

在查看CSS参考手册时,需要注意以下符号:
在这里插入图片描述

比如说,表示可以设置一至四个参数。{1,4}

下面讲CSS3的基础知识。本文讲一下 CSS3 选择器的内容。

我们之前学过 CSS 的选择器,比如:

 div 标签选择器

 .box 类名选择器

 #box id选择器

 div p 后代选择器

 div.box 交集选择器

 div,p,span 并集选择器

 div>p 子代选择器

 * : 通配符

 div+p: 选中div后面相邻的第一个p

 div~p: 选中的div后面所有的p

CSS3新增了许多灵活查找元素的方法,极大的提高了查找元素的效率和精准度。CSS3选择器与 jQuery 中所提供的绝大部分选择器兼容。

属性选择器

属性选择器的标志性符号是 []

匹配含义

  • ^:开头
  • $:结尾
  • *:包含

格式

  • E[title]:选中页面的E元素,并且E存在title属性即可。
  • E[title="abc"]:选中页面的E元素,并且E需要带有title属性,且属性值完全等于abc
  • E[attr~=val]:选择具有att属性且属性值为用空格分隔的字词列表,其中一个等于valE元素。
  • E[attr|=val]:表示要么是一个单独的属性值,要么这个属性值是以"-"分隔的。
  • E[title^="abc"]:选中页面的E元素,并且E需要带有title属性,属性值以abc开头。
  • E[title$="abc"]:选中页面的E元素,并且E需要带有title属性,属性值以abc结尾。
  • E[title*="abc"]:选中页面的E元素,并且E需要带有title属性,属性值任意位置包含abc

比如说,我们可以使用属性选择器去匹配标签的className,非常方便。

属性选择器的作用

属性选择器的作用是根据元素的属性来选择和操作特定的元素。它们可以帮助我们根据元素的属性值来进行样式设置、元素筛选和操作等操作。

属性选择器可以实现以下功能:

  1. 样式设置:通过属性选择器,我们可以选择具有特定属性的元素,并为这些元素设置相应的样式。例如,可以选择所有具有title属性的链接,并为它们设置不同的颜色、字体样式等。

  2. 元素筛选:属性选择器可以用来筛选页面上具有特定属性的元素。例如,可以选择所有具有data-category="food"属性的元素,以便对它们进行特定的处理或操作。

  3. 属性值匹配:属性选择器可以根据属性值的匹配模式来选择元素。可以选择以特定字符串开头或结尾的属性值,或者包含特定字符串的属性值。这使得我们可以更精确地选择需要的元素。

  4. 增强可访问性:通过选择器可以为使用屏幕阅读器和其他辅助技术的用户提供更好的访问体验。例如,可以使用[aria-label]选择器来选择所有具有aria-label属性的元素,并为其设置一些辅助功能。

  5. 提供可定制的主题:选择器可以帮助我们以尽可能少的代码实现一个高度可定制的主题。例如,可以使用变量和选择器等 CSS 特性,将主题作为可重用的代码块打包起来,减少代码量。

  6. 实现动态效果:选择器也可以和CSS的过渡和动画功能一起,实现各种动态效果。例如,通过选择器选择一些元素,并为其指定过渡或动画,当这些元素状态发生改变时,就可以通过过渡或动画实现平滑的过渡和动态效果。

总的来说,选择器是CSS的核心特性之一,它能够为我们提供强大而灵活的功能,使得我们可以轻松地控制和样式化HTML元素,实现各种复杂的效果和布局。选择器的学习和掌握对于前端开发来说非常重要,可以提高工作效率并增强网页的可访问性和用户体验。

这里我们用class属性来举例。代码举例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>选择器 - 属性</title>
    <style>
        body {
            margin: 0;
            padding: 0;
            font-family: '微软雅黑';
            background-color: #F7F7F7;
        }

        .wrapper {
            width: 1024px;
            margin: 0 auto;
        }

        .wrapper > section {
            min-height: 300px;
            margin-bottom: 30px;
            box-shadow: 1px 1px 4px #DDD;
            background-color: #FFF;
        }

        .wrapper > header {
            text-align: center;
            line-height: 1;
            padding: 20px;
            margin-bottom: 10px;
            font-size: 30px;
        }

        .wrapper section > header {
            line-height: 1;
            padding: 10px;
            font-size: 22px;
            color: #333;
            background-color: #EEE;
        }

        .wrapper .wrap-box {
            padding: 20px;
        }

        form {
            width: 300px;
            height: 300px;
            margin: 0 auto;
        }

        form input[type="text"] {
            width: 200px;
            height: 30px;
        }

        form input[type="password"] {
            width: 200px;
            height: 30px;
        }

        .attr1 {

        }

        .download {
        }

        .attr1 a[href="./a.rmvb"] {
            color: red;
        }

        .attr1 a[href="./b.rmvb"] {
            color: pink;
        }

        /*  E[attr~=val] 表示的一个单独的属性值 这个属性值是以空格分隔的*/
        .attr2 a[class~="download"] {
            color: red;
        }

        /*  E[attr|=val] 表示的要么一个单独的属性值 要么这个属性值是以"-"分隔的*/
        .attr3 a[class|="download"] {
            color: red;
        }

        /*  E[attr*=val] 表示的属性值里包含val字符并且在“任意”位置 */
        .attr4 a[class*="download"] {
            color: red;
        }

        /*  E[attr^=val] 表示的属性值里包含val字符并且在“开始”位置 */
        .attr5 a[class^="download"] {
            color: red;
        }

        /*  E[attr$=val] 表示的属性值里包含val字符并且在“结束”位置 */
        .attr6 a[class$="download"] {
            color: red;
        }
    </style>
</head>
<body>
<div class="wrapper">
    <header>CSS3-属性选择器</header>
    <section>
        <header>简介</header>
        <div class="wrap-box">
            <form action="">

                <ul>
                    <li>
                        姓名: <input type="text">
                    </li>
                    <li>
                        密码: <input type="password">
                    </li>

                    <li>
                        性别: <input type="radio"><input type="radio"></li>
                    <li>
                        兴趣: <input type="checkbox" name="" id="">写代码
                    </li>
                    <li>
                        <input type="submit" value="提交">
                    </li>
                </ul>
            </form>
        </div>
    </section>
    <section class="attr1">
        <header>E[attr]</header>
        <div class="wrap-box">
            <a href="./a.rmvb" class="download download-movie">下载</a>
            <a href="./b.rmvb" class="download download-movie">下载</a>
            <a href="./a.mp3" class="download download-music">下载</a>
        </div>
    </section>
    <section class="attr2">
        <header>E[attr~=attr]</header>
        <div class="wrap-box">
            <a href="./a.rmvb" class="download download-movie">下载</a>
            <a href="./b.rmvb" class="download download-movie">下载</a>
            <a href="./a.mp3" class="download download-music">下载</a>
        </div>
    </section>
    <section class="attr3">
        <header>E[attr|=attr]</header>
        <div class="wrap-box">
            <a href="./a.rmvb" class="download">下载</a>
            <a href="./b.rmvb" class="download-movie">下载</a>
            <a href="./a.mp3" class="download-music">下载</a>
        </div>
    </section>
    <section class="attr4">
        <header>E[attr*=val]</header>
        <div class="wrap-box">
            <a href="./a.rmvb" class="download">下载</a>
            <a href="./b.rmvb" class="moviedownload">下载</a>
            <a href="./a.mp3" class="downloadmusic">下载</a>
        </div>
    </section>
    <section class="attr5">
        <header>E[attr^=val]</header>
        <div class="wrap-box">
            <a href="./a.rmvb" class="download">下载</a>
            <a href="./b.rmvb" class="moviedownload">下载</a>
            <a href="./a.mp3" class="downloadmusic">下载</a>
        </div>
    </section>
    <section class="attr6">
        <header>E[attr$=val]</header>
        <div class="wrap-box">
            <a href="./a.rmvb" class="download">下载</a>
            <a href="./b.rmvb" class="moviedownload">下载</a>
            <a href="./a.mp3" class="downloadmusic">下载</a>
        </div>
    </section>
</div>
</body>
</html>

结构伪类选择器

伪类选择器的标志性符号是 :

CSS中有一些伪类选择器,比如 :link:visited:hover:active:focus

CSS3又新增了其它的伪类选择器。这一小段,我们来学习CSS3中的结构伪类选择器:即通过结构来进行筛选。

1、格式:(第一部分)

  • E:first-child 匹配父元素的第一个子元素E。
  • E:last-child 匹配父元素的最后一个子元素E。
  • E:nth-child(n) 匹配父元素的第n个子元素E。注意,盒子的编号是从开始算起,不是从开始算起。10
  • E:nth-child(odd) 匹配奇数
  • E:nth-child(even) 匹配偶数
  • E:nth-last-child(n) 匹配父元素的倒数第n个子元素E。

理解:

(1)这里我们要好好理解父元素的含义,它指的是:以 E 元素的父元素为参考。

(2)注意:以上选择器中所选到的元素的类型,必须是指定的类型E,如果选不中,则无效。这个要好好理解,具体可以看CSS参考手册中的的示例。我们可以理解成:先根据选择器找到选中的全部位置,如果发现某个位置不是类型E,则该位置失效。

(3)另外,这个属性也很有意思。比如,针对下面这样一组标签:

<ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
    <li>6</li>
    <li>7</li>
    <li>8</li>
    <li>9</li>
    <li>10</li>
</ul>

上方代码中:

  • 如果选择器写成 li:nth-child(2),则表示第2个 <li>
  • 如果选择器写成 li:nth-child(n),则表示所有的 <li>。因为此时的 n 表示 0,1,2,3,4,5,6,7,8…(当n小于1时无效,因为n = 0 也是不会选中的)
  • 如果选择器写成 li:nth-child(2n),则表示所有的第偶数个 <li>
  • 如果选择器写成 li:nth-child(2n+1),则表示所有的第奇数个 <li>
  • 如果选择器写成 li:nth-child(-n+5),则表示前5个 <li>
  • 如果选择器写成 li:nth-last-child(-n+5),则表示最后5个 <li>
  • 如果选择器写成 li:nth-child(7n),则表示选中7的倍数。。

上面列举的选择器中,我们只要记住:n 表示 0,1,2,3,4,5,6,7,8…就很容易明白了。

2、格式:(第二部分)

  • E:first-of-type 匹配同类型中的第一个同级兄弟元素E。
  • E:last-of-type 匹配同类型中的最后一个同级兄弟元素E。
  • E:nth-of-type(n) 匹配同类型中的第n个同级兄弟元素E。
  • E:nth-last-of-type(n) 匹配同类型中的倒数第n个同级兄弟元素E。

既然上面这几个选择器带有 type,我们可以这样理解:先在同级里找到所有的E类型,然后根据 n 进行匹配。

3、格式:(第三部分)

  • E:empty 匹配没有任何子节点(包括空格等text节点)的元素E。
  • E:target 匹配相关URL指向的E元素。要配合锚点使用。

在这里插入图片描述

在这里插入图片描述

结构伪类选择器主要用于根据元素在其父元素中的位置或关系进行选择。它们提供了一种方便的方式来选择特定位置的元素,而无需为每个元素添加独立的类或ID。

以下是结构伪类选择器的作用:

  1. :first-child:选择作为其父元素的第一个子元素的元素。
    例如:p:first-child选择第一个p元素。

  2. :last-child:选择作为其父元素的最后一个子元素的元素。
    例如:div:last-child选择最后一个div元素。

  3. :nth-child(n):选择作为其父元素的第n个子元素的元素。
    例如:ul li:nth-child(3)选择ul元素中的第三个li元素。

  4. :nth-last-child(n):选择作为其父元素的倒数第n个子元素的元素。
    例如:ul li:nth-last-child(2)选择ul元素中倒数第二个li元素。

  5. :first-of-type:选择与其兄弟元素相同类型中的第一个元素。
    例如:h2:first-of-type选择同级元素中第一个h2元素。

  6. :last-of-type:选择与其兄弟元素相同类型中的最后一个元素。
    例如:span:last-of-type选择同级元素中最后一个span元素。

  7. :nth-of-type(n):选择与其兄弟元素相同类型中的第n个元素。
    例如:ul li:nth-of-type(odd)选择ul元素中的奇数序号的li元素。

  8. :nth-last-of-type(n):选择与其兄弟元素相同类型中的倒数第n个元素。
    例如:ul li:nth-last-of-type(2)选择ul元素中倒数第二个li元素。

  9. :empty:选择没有任何子节点的元素。
    例如:div:empty选择没有子元素的div元素。

  10. :target:根据URL的片段标识符选择当前活动的目标元素。
    例如:#section1:target选择具有id为"section1"的元素,当它成为文档中的活动目标时(例如,通过链接点击)。

这些结构伪类选择器可以帮助您对网页中的特定元素进行选取和样式设置,使得CSS代码更加灵活和高效。

伪元素选择器

伪元素选择器的标志性符号是 ::

第一部分

  • E::before:设置在元素 E 前面(依据对象树的逻辑结构)的内容,配合 content 属性一起使用。
  • E::after:设置在元素 E 后面(依据对象树的逻辑结构)的内容,配合 content 属性一起使用。

举例:

<style>
  span::before {
    content:"smyhvae";
    color:red;
  }

  span::after {
    content:"永不止步";
    color:yellowgreen;
  }
</style>

<span>生命壹号</span>

通过伪元素选择器,就可以添加出类似于 span 标签的效果(记得要结合 content 属性使用)。

第二部分

  • E::first-letter:设置元素 E 里面的第一位字符的样式。
  • E::first-line:设置元素 E 里面的第一次行的样式。
  • E::selection:设置元素 E 里面被鼠标选中的区域的样式(一般设置颜色和背景色)。

举例:

<style>
  p::first-letter {
    font-size: 3em;
    font-weight: bold;
  }

  p::first-line {
    color: blue;
    text-transform: uppercase;
  }

  ::selection {
    color: white;
    background-color: black;
  }
</style>

<p>This is a sample text for demonstrating the usage of pseudo-element selectors.</p>

通过伪元素选择器,可以设置元素的首字母样式、首行样式,以及选中区域的样式。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

esp32 arduino使用多个串口时如何查看serial1,serial2所对应的引脚定义

如上图所示可以通HardwareSerial.cpp找到起对应的引脚去连接设备即可

5.12.webrtc接口调用过程

嗨&#xff0c;大家好&#xff0c;我是李超&#xff0c;在上节课中呢&#xff0c;我向你介绍了外接口的设计以及我们红接口展开之后的样子&#xff0c;对吧&#xff1f;那今天呢&#xff1f;我们再来看看整个接口调用过程。那整个这个调用过程啊&#xff0c;非常的复杂&#xf…

域控操作二:设置域用户使用简单密码

过程太多简单 直接写出路径更改即可 组策略—计算机配置----策略—Windows设置–安全设置----账户策略–密码策略 按自己想法改就行了 注意一点&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 要么自己设置策略&#xff0c;要么从默认策略改&#xff01;&am…

数学分析:傅里叶级数

卓里奇书好的一点就是&#xff0c;不是直接引出公式&#xff0c;而是告诉你理由。先引出正交的概念&#xff0c;然后在函数空间中&#xff0c;也有正交&#xff0c;只不过是无限维的空间。 这里要注意&#xff0c;明确说明了是有限个。 在函数空间里面&#xff0c;内积是指进行…

CUDA编程入门系列(九)CUDA程序执行与硬件映射

一、GPU流式多处理器 1.kernel的线程组织层次&#xff0c;一个kernel实际上会启动很多线程&#xff0c;这些线程时逻辑上并行的&#xff0c;但是在物理层上不一定是并行的。 2.GPU硬件的一个核心组件时SM&#xff0c;streaming multiprocessor 流式多处理器 3.SM的核心组件包括…

数字电子技术——半导体存储电路

一、半导体存储电路概述 1.存储电路及其分类 存储单元&#xff1a;一位数据 寄存器&#xff1a;一组数据 存储器&#xff1a;大量数据 2.存储单元分类 1&#xff09;静态存储单元 门电路连接而成 2&#xff09;动态存储单元 电容电荷积累 3.存储单元的触发方式与逻辑…

SSH连接华为交换机慢

ssh连接交换机慢是因为交换计算密钥算法阶段默认使用安全性更高的秘钥&#xff0c;由于性能问题导致连接比较慢&#xff0c;如一台华为S5735S-L24T4S-QA2的交换机默认使用如下秘钥&#xff0c;安全行由高到低。 ssh server key-exchange dh_group16_sha512 dh_group15_sha512 …

firewalld常用的基础配置

firewalld防火墙是centos7系统默认的防火墙管理工具&#xff0c;取代了之前的iptables防火墙&#xff0c;也是工作在网络层&#xff0c;属于包过滤防火墙。 支持IPv4、IPv6防火墙设置以及以太网桥支持服务或应用程序直接添加防火墙规则接口拥有两种配置模式&#xff1a;临时模…

C#桶排序算法

前言 桶排序是一种线性时间复杂度的排序算法&#xff0c;它将待排序的数据分到有限数量的桶中&#xff0c;每个桶再进行单独排序&#xff0c;最后将所有桶中的数据按顺序依次取出&#xff0c;即可得到排序结果。 实现原理 首先根据待排序数据&#xff0c;确定需要的桶的数量。…

网工记背命令(6)----链路聚合配置

目录 1.配置手工负载分担模式链路聚合 2.配置LACP模式的链路聚合 3.HUAWEI设备与C厂商设备对接 链路聚合&#xff08;Link Aggregation&#xff09;是将多条物理链路捆绑在一起成为一条逻辑链路&#xff0c;从而增加链路带 宽的技术。 常用配置命令 1、执行命令 interface …

轻重链剖分+启发式合并专题

Codeforces-741D(Arpa’s letter-marked tree and Mehrdad’s Dokhtar-kosh paths) 一棵根为1 的树&#xff0c;每条边上有一个字符&#xff08;a-v共22种&#xff09;。 一条简单路径被称为Dokhtar-kosh当且仅当路径上的字符经过重新排序后可以变成一个回文串。 求每个子树中…

第三章 内存管理 九、基本分段存储管理方式

目录 一、概括 二、什么是分段 三、段表 四、地址转换 五、分段和分页的对比 六、总结 一、概括 基本分段存储管理方式是一种操作系统的内存管理方式&#xff0c;采用这种方式&#xff0c;将进程所需的内存分成若干个段&#xff0c;每个段都可以单独进行管理和保护。 具…

分享一下怎么开发一个陪诊小程序

开发一个陪诊小程序需要综合考虑许多方面&#xff0c;包括但不限于市场需求、用户体验、技术实现和运营策略。以下是一篇以开发陪诊小程序为主题的文章。 一、背景介绍 随着社会的发展和人口老龄化的加剧&#xff0c;越来越多的老年人、病患和孕妇需要就医&#xff0c;而由于各…

攻防世界web篇-unserialize3

得出php代码残篇 将代码补全后再在线php运行工具中进行运行 在浏览器输入后得到下面的界面 这里需要将O:4:“xctf”:1:{s:4:“flag”;s:3:“111”;} 改为 O:4:“xctf”:2:{s:4:“flag”;s:3:“111”;}

【Leetcode】212.单词搜索II(Hard)

一、题目 1、题目描述 给定一个 m x n 二维字符网格 board 和一个单词(字符串)列表 words, 返回所有二维网格上的单词 。 单词必须按照字母顺序,通过 相邻的单元格 内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母在一个单词中…

【java】Java项目从开发到部署生产完整流程梳理

文章目录 前言一、开发环境二、项目搭建2.1 Maven创建项目2.1.1 创建maven项目2.1.2 引入依赖2.1.3 maven常用命令 三、SpringBoot基础配置四、项目打包4.1 打包jar4.2 打包war4.2.1 修改项目打包为war包4.2.2 排除内嵌的tomcat&#xff0c;引入外部tomcat4.2.3 添加servlet-ap…

Unity可视化Shader工具ASE介绍——8、UI类型的特效Shader编写

阿赵的Unity可视化Shader工具ASE介绍目录 Unity的UGUI图片特效角色闪卡效果 大家好&#xff0c;我是阿赵。   继续介绍Unity可视化Shader编辑插件ASE的使用。这次讲一下UI类特效Shader的写法。 一、例子说明 这次编写一个Shader&#xff0c;给一张UGUI里面的图片增加一个闪卡…

攻防世界web篇-Training-WWW-Robots

直接点击给出的地址&#xff0c;然后会转到另一个网页界面&#xff0c;在这个界面&#xff0c;已经给出了提示&#xff0c;robots.txt 在浏览器中&#xff0c;直接在地址的后面加上robots.txt&#xff0c;会进到下面这个界面 因为对php语言一窍不通&#xff0c;所以这里纯粹就…

Swagger有哪些非常重要的注释?

Swagger是一种用于描述和定义RESTful API的强大工具&#xff0c;它提供了一种规范来编写API文档&#xff0c;生成客户端SDK以及进行自动化测试。其中的注释&#xff08;Annotations&#xff09;在Swagger规范中扮演着关键的角色&#xff0c;用于为API端点、操作、模型等添加元数…

在UniApp中使用uni.makePhoneCall方法调起电话拨打功能

目录 1.在manifest.json文件中添加权限 2. 组件中如何定义 3.如何授权 4.相关知识点总结 1.在manifest.json文件中添加权限 {"permissions": {"makePhoneCall": {"desc": "用于拨打电话"}} }2. 组件中如何定义 <template>…