Spring Boot 快速入门与项目实战详解 (全网最易懂教程)

spring boot通过自动化配置、内嵌服务器、starter poms和生产就绪特性极大简化了java开发。1. 自动化配置根据引入的依赖自动完成大部分配置工作,减少手动编写配置文件的需要;2. 内嵌服务器将tomcat等web容器集成到应用中,实现jar包一键运行;3. starter poms统一管理相关依赖及其版本,避免依赖冲突;4. 提供健康检查、度量等生产级功能,提升运维效率。通过spring initializr可快速生成项目骨架,结合spring data jpa能高效完成数据库操作,使开发者专注于业务逻辑,显著提高开发效率。

Spring Boot 快速入门与项目实战详解 (全网最易懂教程)

Spring Boot,简单来说,就是一套能让你用Java快速开发应用的“脚手架”和“加速器”。它极大地简化了Spring应用的搭建和开发过程,让我们这些开发者能更专注于业务逻辑,而不是繁琐的配置。如果你想快速上手一个项目,或者对Spring框架感到头疼,Spring Boot绝对是你值得一试的选择,它能让你在短时间内跑起来一个功能完备的应用,简直是开发效率的“神助攻”。

Spring Boot 快速入门与项目实战详解 (全网最易懂教程)

解决方案

要真正理解Spring Boot为什么能做到“快速入门与项目实战”,得从它几个核心设计理念说起。它不是一个全新的框架,而是对Spring生态系统的一次巧妙整合和优化。想想看,以前我们用Spring开发,是不是总要写一大堆XML配置,或者Java配置类也少不了?依赖管理也是个头疼事,版本冲突时有发生。Spring Boot就是来解决这些痛点的。

它引入了“约定优于配置”的思想,很多东西你不用管,它自己就帮你配好了。比如,你引入了Web依赖,它就默认帮你启动一个内嵌的Tomcat服务器,你写个Controller就能直接跑起来。还有“Starter POMs”,这玩意儿简直是依赖管理的救星,一个spring-boot-starter-web就把所有Web开发需要的依赖都拉进来了,还帮你管理好了版本,再也不用担心“依赖地狱”了。

Spring Boot 快速入门与项目实战详解 (全网最易懂教程)

所以,我们的解决方案就是:拥抱Spring Boot的这些自动化和简化特性,从一个最基础的Web应用开始,逐步深入到数据库集成、API开发,你会发现整个过程比想象中顺畅得多。它把很多幕后的复杂性都隐藏了,让你能更快地看到成果,这对于学习和项目初期验证来说,太重要了。

Spring Boot真的能让开发变得更简单吗?它的核心优势体现在哪里?

说实话,我第一次接触Spring Boot的时候,简直是惊呆了。那时候还在为Spring MVC的XML配置头疼,突然发现Spring Boot一个注解、一个依赖就能搞定,那种感觉就像从“石器时代”一下子跳到了“信息时代”。它确实让Java开发,特别是Web应用开发,变得异常简单和高效。

Spring Boot 快速入门与项目实战详解 (全网最易懂教程)

它的核心优势,我觉得主要体现在几个方面:

首先是自动化配置(Auto-Configuration)。这个是Spring Boot的灵魂。它会根据你项目里引入的jar包,自动帮你配置Spring应用。比如,你加了spring-boot-starter-data-jpa,它就会自动检测你有没有数据源配置,然后帮你配置好DataSource、EntityManagerFactory等等。这种“智能”让我省去了大量原本需要手动编写的配置代码,极大地减少了出错的可能性,也提高了开发效率。我只需要关心业务逻辑,底层那些繁琐的配置,Spring Boot都替我搞定了。

接着是内嵌服务器(Embedded Servers)。以前部署Java Web应用,你得先装个Tomcat、Jetty或者Undertow,然后把你的war包扔进去。现在Spring Boot直接把这些服务器内嵌到你的应用里,一个jar包就能独立运行,直接java -jar your-app.jar就完事儿了。这对于开发、测试和部署来说,简直是革命性的便利。想想看,一套代码,一个包,哪里都能跑,多省心!

然后是Starter POMs。这东西简直是依赖管理的“救世主”。以前,为了引入一个功能,我可能要找好几个依赖,还得小心翼翼地匹配版本,稍微不注意就冲突了。Spring Boot的Starter就是把一系列相关的依赖打包在一起,比如spring-boot-starter-web包含了Tomcat、Spring MVC等所有Web开发所需的依赖,并且版本都是兼容的。这大大简化了项目构建的复杂度,让开发者能更快地搭建起一个功能完备的项目骨架。

最后,不得不提的是生产就绪特性。Spring Boot不仅仅是开发阶段的利器,它还为生产环境提供了很多开箱即用的功能,比如健康检查、度量、外部化配置等。通过Spring Boot Actuator,我们可以轻松监控和管理运行中的应用。这些特性让我们的应用从开发到部署再到运维,整个生命周期都变得更加顺畅和可控。

总而言之,Spring Boot的这些特性,就像给Java开发者装上了“翅膀”,让我们可以更快速、更优雅地构建和部署应用。它不是简单地把复杂性隐藏起来,而是通过一套智能的约定和自动化机制,让复杂性变得可管理,最终达到“让开发更简单”的目标。

从零开始:如何搭建一个Spring Boot项目并运行第一个应用?

搭建一个Spring Boot项目,现在简直是“傻瓜式”操作,你甚至不需要自己敲一行配置。最常用的方法就是通过Spring Initializr。

访问Spring Initializr:打开浏览器,输入start.spring.io。这是一个由Spring官方提供的项目生成器。

选择项目配置:

Project: 我通常选Maven Project,因为习惯了,当然Gradle也行。Language: Java。Spring Boot: 选择一个稳定的最新版本,比如3.2.x或者2.7.x。Project Metadata:Group: 比如com.exampleArtifact: 比如demo (这将是你的项目名)Name: 默认和Artifact一样。Package name: 默认和Group+Artifact组合。Packaging: Jar (因为我们用内嵌服务器,不需要war包)。Java: 选择你本地JDK的版本,比如17或21。Dependencies: 这是关键!点击“Add Dependencies…”,搜索并添加:Spring Web: 用于构建Web应用和RESTful API。Spring Boot DevTools: 这个是开发利器,可以实现热部署,修改代码后自动重启应用,非常方便。

生成并下载项目:配置好后,点击“Generate”按钮,你会得到一个zip文件。解压它。

导入到IDE:打开你喜欢的IDE(比如IntelliJ IDEA、Eclipse),选择“Import Project”或“Open”,然后指向你解压后的项目根目录。IDE会自动识别这是一个Maven或Gradle项目,并帮你导入所有依赖。

编写你的第一个应用:找到src/main/java/com/example/demo(或者你自己的包名)下的主应用类,通常是DemoApplication.java

在这个类的同级目录下,新建一个Java类,比如HelloController.java

package com.example.demo; // 确保包名正确import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;@RestController // 这是一个REST控制器public class HelloController {    @GetMapping("/hello") // 映射到 /hello 路径的GET请求    public String hello() {        return "Hello, Spring Boot! 这是我的第一个应用。";    }}

一个小提示: @RestController其实是@Controller@ResponseBody的组合,意味着这个类的所有方法都会直接返回数据(比如字符串、JSON),而不是视图。

运行应用:在IDE里,找到主应用类(DemoApplication.java),右键点击,选择“Run ‘DemoApplication.main()’”。或者你也可以在命令行进入项目根目录,运行mvn spring-boot:run(如果是Maven项目)。

你会看到控制台输出Spring Boot的启动日志,最后会显示类似“Started DemoApplication in X.XXX seconds (JVM running for Y.YYY)”的信息,并且提示Tomcat在某个端口(默认8080)启动。

验证:打开浏览器,访问http://localhost:8080/hello。如果一切顺利,你将看到“Hello, Spring Boot! 这是我的第一个应用。”这句话。

恭喜你!你已经成功搭建并运行了你的第一个Spring Boot应用。从这里开始,你可以尝试修改HelloController的代码,比如添加一个带参数的接口,或者返回一个JSON对象,DevTools的魔力就会显现,你改完代码保存后,应用会自动重启,刷新浏览器就能看到效果。这种即时反馈的开发体验,是Spring Boot让人爱不释手的原因之一。

Spring Boot项目实战:如何集成数据库与构建一个简单的CRUD应用?

光是跑个“Hello World”当然不够,Spring Boot的强大在于它能让你快速构建真实世界的应用。集成数据库是绝大多数应用绕不开的话题,下面我们就以一个简单的用户管理(CRUD:创建、读取、更新、删除)为例,看看如何用Spring Boot和Spring Data JPA来搞定数据库操作。

这里我们选用H2数据库,因为它是一个内存数据库,非常适合开发和测试,不需要额外安装,启动应用时会自动创建数据库和表。当然,换成MySQL、PostgreSQL也只是改几个配置和依赖的事儿。

添加数据库相关依赖:回到start.spring.io或者直接修改你项目里的pom.xml(如果是Maven)。在标签里添加:

    org.springframework.boot    spring-boot-starter-data-jpa    com.h2database    h2    runtime<!-- MySQL Connector (如果用MySQL,则替换H2)    mysql    mysql-connector-java    runtime-->

小提醒: 如果是Spring Boot 3.x,MySQL连接器可能需要mysql-connector-j

配置数据源:src/main/resources目录下的application.properties(或者application.yml)文件中添加数据库配置。

# H2 Database Configurationspring.datasource.url=jdbc:h2:mem:testdbspring.datasource.driverClassName=org.h2.Driverspring.datasource.username=saspring.datasource.password=spring.h2.console.enabled=true # 开启H2控制台,方便查看数据spring.h2.console.path=/h2-console # H2控制台访问路径# JPA Configuration (可选,但推荐)spring.jpa.hibernate.ddl-auto=update # 启动时自动更新数据库表结构spring.jpa.show-sql=true # 在控制台打印SQL语句spring.jpa.properties.hibernate.format_sql=true # 格式化SQL语句

ddl-auto=update在开发阶段很方便,它会自动根据你的实体类创建或更新表结构。但在生产环境,通常会设置为nonevalidate,配合Flyway/Liquibase等工具进行数据库版本管理。

创建实体(Entity):新建一个Java类,比如User.java,表示数据库中的一张表。

package com.example.demo.model; // 建议放在model包下import jakarta.persistence.Entity;import jakarta.persistence.GeneratedValue;import jakarta.persistence.GenerationType;import jakarta.persistence.Id;@Entity // 标记这是一个JPA实体public class User {    @Id // 标记为主键    @GeneratedValue(strategy = GenerationType.IDENTITY) // 自增ID    private Long id;    private String name;    private String email;    // 构造函数 (JPA需要无参构造函数)    public User() {}    public User(String name, String email) {        this.name = name;        this.email = email;    }    // Getter和Setter方法    public Long getId() { return id; }    public void setId(Long id) { this.id = id; }    public String getName() { return name; }    public void setName(String name) { this.name = name; }    public String getEmail() { return email; }    public void setEmail(String email) { this.email = email; }    @Override    public String toString() {        return "User{" +               "id=" + id +               ", name='" + name + ''' +               ", email='" + email + ''' +               '}';    }}

一个小的思考: 为什么需要@Entity@Id这些注解?它们是JPA规范的一部分,告诉Hibernate(Spring Data JPA底层默认的ORM框架)如何将Java对象映射到数据库表。

创建Repository接口:新建一个接口,比如UserRepository.java,继承JpaRepository

package com.example.demo.repository; // 建议放在repository包下import com.example.demo.model.User;import org.springframework.data.jpa.repository.JpaRepository;import org.springframework.stereotype.Repository;@Repository // 标记这是一个Spring管理的组件public interface UserRepository extends JpaRepository {    // JpaRepository 已经提供了基本的CRUD方法,比如 save(), findById(), findAll(), deleteById()    // 你也可以在这里定义自己的查询方法,Spring Data JPA会根据方法名自动实现    User findByName(String name); // 示例:根据名字查询用户}

JpaRepository表示这个Repository操作User实体,并且它的主键类型是Long。Spring Data JPA的强大之处在于,你不需要写任何实现类,它会自动为你生成这些方法的实现!这简直是开发者的福音,省去了大量样板代码。

创建控制器(Controller)处理API请求:修改或新建一个控制器,比如UserController.java

package com.example.demo.controller; // 建议放在controller包下import com.example.demo.model.User;import com.example.demo.repository.UserRepository;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.http.HttpStatus;import org.springframework.http.ResponseEntity;import org.springframework.web.bind.annotation.*;import java.util.List;import java.util.Optional;@RestController@RequestMapping("/api/users") // 所有接口都以 /api/users 开头public class UserController {    @Autowired // 注入UserRepository    private UserRepository userRepository;    // 创建用户 (Create)    @PostMapping    public ResponseEntity createUser(@RequestBody User user) {        User savedUser = userRepository.save(user);        return new ResponseEntity(savedUser, HttpStatus.CREATED);    }    // 获取所有用户 (Read All)    @GetMapping    public List getAllUsers() {        return userRepository.findAll();    }    // 根据ID获取用户 (Read One)    @GetMapping("/{id}")    public ResponseEntity getUserById(@PathVariable Long id) {        Optional user = userRepository.findById(id);        return user.map(value -> new ResponseEntity(value, HttpStatus.OK))                   .orElseGet(() -> new ResponseEntity(HttpStatus.NOT_FOUND));    }    // 更新用户 (Update)    @PutMapping("/{id}")    public ResponseEntity updateUser(@PathVariable Long id, @RequestBody User userDetails) {        Optional userOptional = userRepository.findById(id);        if (userOptional.isPresent()) {            User user = userOptional.get();            user.setName(userDetails.getName());            user.setEmail(userDetails.getEmail());            User updatedUser = userRepository.save(user);            return new ResponseEntity(updatedUser, HttpStatus.OK);        } else {            return new ResponseEntity(HttpStatus.NOT_FOUND);        }    }    // 删除用户 (Delete)    @DeleteMapping("/{id}")    public ResponseEntity deleteUser(@PathVariable Long id) {        try {            userRepository.deleteById(id);            return new ResponseEntity(HttpStatus.NO_CONTENT);        } catch (Exception e) {            return new ResponseEntity(HttpStatus.INTERNAL_SERVER_ERROR);        }    }}

一些思考:

@Autowired:这是Spring的依赖注入机制,它会自动找到UserRepository的实例并注入到UserController中。@RequestBody:用于将HTTP请求体中的JSON或XML数据绑定到Java对象上。@PathVariable:用于从URL路径中提取变量。ResponseEntity:提供更灵活的HTTP响应控制,可以设置状态码、头部等。

运行和测试:再次运行你的Spring Boot应用。

H2控制台: 访问http://localhost:8080/h2-console。连接信息填jdbc:h2:mem:testdb,用户sa,密码空。点击Connect后,你会看到USER表已经自动创建了。

API测试: 你可以使用Postman、Insomnia或者curl来测试这些API。

创建用户 (POST):URL: http://localhost:8080/api/usersMethod: POSTHeaders: Content-Type: application/jsonBody (Raw JSON):

{    "name": "张三",    "email": "zhangsan@example.com"}

获取所有用户 (GET):URL: http://localhost:8080/api/usersMethod: GET

获取单个用户 (GET):URL: http://localhost:8080/api/users/1 (假设ID为1)Method: GET

更新用户 (PUT):URL: http://localhost:8080/api/users/1Method: PUTHeaders: Content-Type: application/jsonBody (Raw JSON):

{    "name": "张三丰",    "email": "zhangsanfeng@example.com"}

删除用户 (DELETE):URL: http://localhost:8080/api/users/1Method: DELETE

通过这个例子,你会发现Spring Boot结合Spring Data JPA,让数据库操作变得非常直观和高效。你几乎不需要手写SQL,大部分操作都通过Java对象和Repository接口完成。这种“面向对象”的

以上就是Spring Boot 快速入门与项目实战详解 (全网最易懂教程)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/139536.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月30日 20:31:48
下一篇 2025年11月30日 21:03:19

相关推荐

  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 使用 SVG 如何实现自定义宽度、间距和半径的虚线边框?

    使用 svg 实现自定义虚线边框 如何实现一个具有自定义宽度、间距和半径的虚线边框是一个常见的前端开发问题。传统的解决方案通常涉及使用 border-image 引入切片图片,但是这种方法存在引入外部资源、性能低下的缺点。 为了避免上述问题,可以使用 svg(可缩放矢量图形)来创建纯代码实现。一种方…

    2025年12月24日
    100
  • 如何让“元素跟随文本高度,而不是撑高父容器?

    如何让 元素跟随文本高度,而不是撑高父容器 在页面布局中,经常遇到父容器高度被子元素撑开的问题。在图例所示的案例中,父容器被较高的图片撑开,而文本的高度没有被考虑。本问答将提供纯css解决方案,让图片跟随文本高度,确保父容器的高度不会被图片影响。 解决方法 为了解决这个问题,需要将图片从文档流中脱离…

    2025年12月24日
    000
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 如何利用 CSS 选中激活标签并影响相邻元素的样式?

    如何利用 css 选中激活标签并影响相邻元素? 为了实现激活标签影响相邻元素的样式需求,可以通过 :has 选择器来实现。以下是如何具体操作: 对于激活标签相邻后的元素,可以在 css 中使用以下代码进行设置: li:has(+li.active) { border-radius: 0 0 10px…

    2025年12月24日
    100
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200
  • 为什么我的 Safari 自定义样式表在百度页面上失效了?

    为什么在 Safari 中自定义样式表未能正常工作? 在 Safari 的偏好设置中设置自定义样式表后,您对其进行测试却发现效果不同。在您自己的网页中,样式有效,而在百度页面中却失效。 造成这种情况的原因是,第一个访问的项目使用了文件协议,可以访问本地目录中的图片文件。而第二个访问的百度使用了 ht…

    2025年12月24日
    000
  • 如何用前端实现 Windows 10 设置界面的鼠标移动探照灯效果?

    如何在前端实现 Windows 10 设置界面中的鼠标移动探照灯效果 想要在前端开发中实现 Windows 10 设置界面中类似的鼠标移动探照灯效果,可以通过以下途径: CSS 解决方案 DEMO 1: Windows 10 网格悬停效果:https://codepen.io/tr4553r7/pe…

    2025年12月24日
    000
  • 使用CSS mask属性指定图片URL时,为什么浏览器无法加载图片?

    css mask属性未能加载图片的解决方法 使用css mask属性指定图片url时,如示例中所示: mask: url(“https://api.iconify.design/mdi:apple-icloud.svg”) center / contain no-repeat; 但是,在网络面板中却…

    2025年12月24日
    000
  • 如何用CSS Paint API为网页元素添加时尚的斑马线边框?

    为元素添加时尚的斑马线边框 在网页设计中,有时我们需要添加时尚的边框来提升元素的视觉效果。其中,斑马线边框是一种既醒目又别致的设计元素。 实现斜向斑马线边框 要实现斜向斑马线间隔圆环,我们可以使用css paint api。该api提供了强大的功能,可以让我们在元素上绘制复杂的图形。 立即学习“前端…

    2025年12月24日
    000
  • 图片如何不撑高父容器?

    如何让图片不撑高父容器? 当父容器包含不同高度的子元素时,父容器的高度通常会被最高元素撑开。如果你希望父容器的高度由文本内容撑开,避免图片对其产生影响,可以通过以下 css 解决方法: 绝对定位元素: .child-image { position: absolute; top: 0; left: …

    2025年12月24日
    000
  • CSS 帮助

    我正在尝试将文本附加到棕色框的左侧。我不能。我不知道代码有什么问题。请帮助我。 css .hero { position: relative; bottom: 80px; display: flex; justify-content: left; align-items: start; color:…

    2025年12月24日 好文分享
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 如何用 CSS Paint API 实现倾斜的斑马线间隔圆环?

    实现斑马线边框样式:探究 css paint api 本文将探究如何使用 css paint api 实现倾斜的斑马线间隔圆环。 问题: 给定一个有多个圆圈组成的斑马线图案,如何使用 css 实现倾斜的斑马线间隔圆环? 答案: 立即学习“前端免费学习笔记(深入)”; 使用 css paint api…

    2025年12月24日
    000
  • 如何使用CSS Paint API实现倾斜斑马线间隔圆环边框?

    css实现斑马线边框样式 想定制一个带有倾斜斑马线间隔圆环的边框?现在使用css paint api,定制任何样式都轻而易举。 css paint api 这是一个新的css特性,允许开发人员创建自定义形状和图案,其中包括斑马线样式。 立即学习“前端免费学习笔记(深入)”; 实现倾斜斑马线间隔圆环 …

    2025年12月24日
    100

发表回复

登录后才能评论
关注微信