0基础学前端 day4

大家好,欢迎来到无限大的频道。

今天继续带领大家开始0基础学前端。

一、 什么是Bootstrap框架?

Bootstrap是一个开源前端框架,于2011年由Twitter的开发团队开发并发布。其主要目的是简化开发过程,并使开发者能够轻松快速地构建响应式网站和应用程序。它提供了一系列的HTML、CSS和JavaScript组件,如网格系统、按钮、导航栏、表单等,帮助开发者创建一致且美观的用户界面。Bootstrap最大的优势在于其响应式设计,能够自动适应各种设备尺寸。此外,Bootstrap的丰富文档和活跃的社区使其成为初学者和专业开发者的热门选择。

著名的应用

众多网站和应用程序使用Bootstrap来构建其前端界面。其中一些著名的例子包括:

  • Twitter: 作为Bootstrap的发源地,Twitter为初始开发提供了很多资源。
  • LinkedIn: 职业社交平台LinkedIn利用Bootstrap确保其界面的可维护性和高效性。
  • Vogue: 著名时尚杂志Vogue的网站也使用了Bootstrap来提高用户体验。

这些企业利用Bootstrap来快速构建和迭代其产品,同时确保跨设备的用户体验一致性。

二、Bootstrap的重要和常用内容

1. 网格系统(Grid System)

Bootstrap的网格系统是其核心之一,它使用灵活的容器(container)来进行布局,通过行(row)和列(col)的组合构成。默认情况下,它基于12列的布局,允许你通过组合不同的列宽来创建不同的页面布局。网格系统通过响应式设计,确保布局在各种设备上都能良好显示。

  • 容器(Container): container类用于固定宽度的布局,而container-fluid用于全宽度布局。它们是每行的父元素。

    <div class="container"><!-- Content here -->
    </div>
    
  • 行(Row): row类用于水平排列列。每个row必须包含在container内。

    <div class="row"><div class="col">Column</div>
    </div>
    
  • 列(Columns): col-*类定义列的宽度。可以是动态(col)或固定比例(col-md-4)。

    <div class="col-md-4">Medium 4/12</div>
    <div class="col-md-8">Medium 8/12</div>
    

2. 排版(Typography)

Bootstrap提供了一整套一致的排版样式,包括标题、段落、文本格式化和对齐选项。默认字体使用"Helvetica Neue", Helvetica, Arial, sans-serif。

  • 标题和副标题: 使用<h1><h6>标签自带Bootstrap的样式。

  • 字体大小与颜色: 提供了一系列帮助类,如text-primarytext-secondary等,用于快速修改文本颜色。

    <h1 class="text-primary">Primary Heading</h1>
    <p class="lead">This is a lead paragraph.</p>
    

3. 组件(Components)

Bootstrap提供了丰富的UI组件,这些组件已经过精心设计、测试和调试,使得它们在各类项目中高度复用和便捷使用。

  • 按钮(Buttons): 多种样式可选,如btn-primary(蓝色),btn-secondary(灰色)等。

    <button type="button" class="btn btn-primary">Primary Button</button>
    
  • 导航栏(Navbar): 提供响应式、可定制的导航栏。

    <nav class="navbar navbar-expand-lg navbar-light bg-light"><a class="navbar-brand" href="#">Brand</a>
    </nav>
    
  • 模态框(Modal): 用于创建模态提示和对话框。

    <button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal"> Open Modal</button>
    

4. JavaScript插件(JavaScript Plugins)

Bootstrap包含了一些JavaScript插件,用于增强UI的交互性。这些插件大多依赖于jQuery,因此需要在页面中引入jQuery。

  • 模态框(Modals): 提供对话框、多媒体查看器、lightbox等功能。

  • 轮播(Carousel): 用于创建响应式、自动循环的图片或内容滑块。

    <div id="carouselExample" class="carousel slide" data-ride="carousel"><!-- Carousel content here -->
    </div>
    

5. 表单(Forms)

Bootstrap提供了格式统一且美观的表单样式,包括输入框、选择框、单选按钮、复选框等,所有组件均有一致的间距和风格。

  • 表单控制(Form Control): 使用类如form-control来美化输入元素。

    <input type="text" class="form-control" placeholder="Enter text">
    
  • 表单布局: 支持水平表单和内联表单布局样式,为复杂的表单设计提供了良好的基础。

通过使用Bootstrap这一前端框架,可以大幅减少开发时间,提高代码可维护性,并确保在不同设备上的一致性。Bootstrap的灵活性和易用性使其成为初学者和经验丰富的开发者都青睐的选择。

自定义样式(Customizing Styles)

开发者可以通过覆盖Bootstrap的默认样式或者直接编辑其源代码来定制自己想要的风格。此外,Bootstrap 4开始引入的SCSS支持更是提升了其定制的灵活性。

使用Bootstrap优化代码实例

个人主页优化

首先引入Bootstrap的CSS文件:

<head><!-- Add Bootstrap CSS CDN link --><link href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" rel="stylesheet">
</head>

然后,将代码中的结构修改以适应Bootstrap的类,如使用containerrowcol进行布局结构的调整。

<!DOCTYPE html>  
<html lang="zh-CN">  
<head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, initial-scale=1.0">  <title>我的个人主页</title>  <!-- 替换为国内可访问的Bootstrap CSS CDN -->  <link href="https://cdn.jsdelivr.net/npm/bootstrap@4.5.2/dist/css/bootstrap.min.css" rel="stylesheet">  <link rel="stylesheet" href="styles.css">  
</head>  
<body>  <!-- Navbar -->  <nav class="navbar navbar-expand-lg navbar-dark bg-dark">  <a class="navbar-brand" href="#">个人主页</a>  <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">  <span class="navbar-toggler-icon"></span>  </button>  <div class="collapse navbar-collapse" id="navbarNav">  <ul class="navbar-nav ml-auto">  <li class="nav-item active"><a class="nav-link" href="#">首页</a></li>  <li class="nav-item"><a class="nav-link" href="#bio">关于我</a></li>  <li class="nav-item"><a class="nav-link" href="#hobbies">兴趣</a></li>  <li class="nav-item"><a class="nav-link" href="#contact">联系</a></li>  </ul>  </div>  </nav>  <!-- Header -->  <header class="header bg-dark text-white text-center py-3">  <h1>欢迎来到我的个人主页</h1>  </header>  <!-- Main Content -->  <main class="content container mt-4">  <div class="row">  <!-- Bio Section -->  <section id="bio" class="col-lg-4 col-md-6 mb-4">  <div class="card shadow-sm">  <img src="https://wxdwuxd.oss-cn-beijing.aliyuncs.com/4027b724a62b206a73ba495e732af2b.jpg" class="card-img-top" alt="Profile Image">  <div class="card-body">  <h2 class="card-title">关于我</h2>  <p class="card-text">你好!我是一个前端开发的初学者,正在学习如何创建美观且有用的网页。</p>  </div>  </div>  </section>  <!-- Hobbies Section -->  <section id="hobbies" class="col-lg-4 col-md-6 mb-4">  <div class="card shadow-sm">  <div class="card-body">  <h2 class="card-title">爱好与兴趣</h2>  <ul class="list-group list-group-flush">  <li class="list-group-item">编程</li>  <li class="list-group-item">阅读</li>  <li class="list-group-item">旅行</li>  </ul>  </div>  </div>  </section>  <!-- Projects Section -->  <section class="col-lg-4 col-md-6 mb-4">  <div class="card shadow-sm">  <div class="card-body">  <h2 class="card-title">查看我的作品</h2>  <ul class="list-group list-group-flush">  <li class="list-group-item"><a href="#">我的第一个项目</a></li>  <li class="list-group-item"><a href="#">一个有趣的项目</a></li>  </ul>  </div>  </div>  </section>  </div>  <!-- Contact Form Section -->  <section id="contact" class="py-4 bg-light rounded shadow-sm">  <h2 class="text-center">联系我</h2>  <form class="px-4">  <div class="form-row">  <div class="form-group col-md-6">  <label for="name">姓名</label>  <input type="text" class="form-control" id="name" placeholder="输入姓名">  </div>  <div class="form-group col-md-6">  <label for="email">邮箱</label>  <input type="email" class="form-control" id="email" placeholder="输入邮箱">  </div>  </div>  <div class="form-group">  <label for="message">留言</label>  <textarea class="form-control" id="message" rows="4" placeholder="输入留言"></textarea>  </div>  <button type="submit" class="btn btn-primary">发送</button>  </form>  </section>  </main>  <!-- Footer -->  <footer class="footer bg-dark text-white text-center py-2">  <p>联系我:<a class="text-white" href="https://blog.csdn.net/wxdzuishaui?spm=1010.2135.3001.5343">我的博客</a></p>  </footer>  </body>  
</html>

把对应的css代码也进行一个调整

body {  margin: 0;  font-family: 'Roboto', sans-serif;  
}  .header {  text-shadow: 2px 2px 4px #000000;  
}  .navbar-brand,  
.nav-link {  font-size: 1.1em;  
}  .content {  padding: 20px 0;  
}  .card {  border: none; /* 清除默认边框 */  border-radius: 10px;  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);  transition: transform 0.3s;  overflow: hidden;  
}  .card:hover {  transform: scale(1.05);  
}  .card-img-top {  object-fit: cover;  height: 200px;  
}  .card-title {  font-size: 1.5em;  
}  ul {  list-style: none;  padding: 0;  
}  li {  margin-bottom: 10px;  
}  a {  color: #0066cc;  text-decoration: none;  
}  a:hover {  text-decoration: underline;  color: #004999;  
}  .form-control {  margin-bottom: 15px;  
}  .btn-primary {  background-color: #0066cc;  border-color: #0066cc;  
}  .btn-primary:hover {  background-color: #004999;  border-color: #004999;  
}  .footer {  background-color: #333;  color: white;  text-align: center;  padding: 10px;  width: 100%;  box-shadow: 0 -3px 8px rgba(0, 0, 0, 0.2);  
}

KD介绍代码优化

如上,在<head>中引入Bootstrap的CSS。在<body>中用Bootstrap类替换现有的结构,以实现响应式设计。

<!DOCTYPE html>  
<html lang="zh-CN">  
<head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, initial-scale=1.0">  <title>凯文·杜兰特</title>  <!-- 使用国内可访问的Bootstrap CSS CDN -->  <link href="https://cdn.jsdelivr.net/npm/bootstrap@4.5.2/dist/css/bootstrap.min.css" rel="stylesheet">  <link rel="stylesheet" href="kd.css">  
</head>  
<body>  <!-- Navbar -->  <nav class="navbar navbar-expand-lg navbar-dark bg-dark">  <a class="navbar-brand" href="#">杜兰特主页</a>  <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">  <span class="navbar-toggler-icon"></span>  </button>  <div class="collapse navbar-collapse" id="navbarNav">  <ul class="navbar-nav ml-auto">  <li class="nav-item active"><a class="nav-link" href="#">首页</a></li>  <li class="nav-item"><a class="nav-link" href="#bio">简介</a></li>  <li class="nav-item"><a class="nav-link" href="#career">职业生涯</a></li>  <li class="nav-item"><a class="nav-link" href="#teams">球队历程</a></li>  <li class="nav-item"><a class="nav-link" href="#achievements">成就</a></li>  <li class="nav-item"><a class="nav-link" href="#personal-life">个人生活</a></li>  </ul>  </div>  </nav>  <header class="header">  <h1>凯文·杜兰特</h1>  </header>  <main class="container content mt-4">  <div class="row">  <div class="col-md-4">  <section class="image text-center mb-4">  <img src="https://wxdwuxd.oss-cn-beijing.aliyuncs.com/6fa6ec013f49061e5c313827b6099f2.png" alt="凯文·杜兰特" class="rounded-circle img-fluid">  </section>  </div>  <div class="col-md-8">  <section id="bio" class="bio mb-4">  <h2>简介</h2>  <p>凯文·杜兰特(Kevin Durant)是NBA著名篮球运动员,司职小前锋...</p>  </section>  <section id="career" class="career mb-4">  <h2>职业生涯</h2>  <p>杜兰特的职业生涯始于2007年,他在2007年NBA选秀中被西雅图超音速以第一顺位选中...</p>  </section>  </div>  </div>  <div class="row">  <div class="col-md-6">  <section id="teams" class="teams mb-4">  <h2>球队历程</h2>  <ul class="list-group">  <li class="list-group-item">西雅图超音速 (2007-2008)</li>  <li class="list-group-item">俄克拉荷马城雷霆 (2008-2016)</li>  <li class="list-group-item">金州勇士 (2016-2019)</li>  <li class="list-group-item">布鲁克林篮网 (2019-2022)</li>  <li class="list-group-item">菲尼克斯太阳 (2022-至今)</li>  </ul>  </section>  </div>  <div class="col-md-6">  <section id="achievements" class="achievements mb-4">  <h2>成就</h2>  <ul class="list-group">  <li class="list-group-item">两届NBA总冠军 (2017, 2018)</li>  <li class="list-group-item">四届NBA得分王 (2010, 2011, 2012, 2014)</li>  <li class="list-group-item">两届总决赛MVP (2017, 2018)</li>  <li class="list-group-item">NBA常规赛MVP (2014)</li>  <li class="list-group-item">2021年东京奥运会金牌</li>  <li class="list-group-item">十届NBA全明星</li>  </ul>  </section>  </div>  </div>  <section id="personal-life" class="personal-life mb-5">  <h2>个人生活</h2>  <p>杜兰特在场外也十分活跃,他积极参与慈善和社区活动,成立了「凯文·杜兰特慈善基金会」,旨在帮助年轻人和改善社区生活。此外,他还是投资者,参与了多个初创公司的投资。</p>  </section>  </main>  <footer class="footer bg-dark text-white text-center py-2">  <p>© 2024 凯文·杜兰特粉丝页面</p>  </footer>  
</body>  
</html>
body {  font-family: 'Roboto', sans-serif;  color: #f0f0f0;  margin: 0;  padding: 0;  background-color: #121212;  
}  .header {  background: linear-gradient(135deg, #1a1a1a 25%, #000000 100%);  color: #f0f0f0;  text-align: center;  padding: 20px;  text-shadow: 2px 2px 5px #000000;  
}  .content {  padding: 0 15px;  
}  .img-fluid {  max-width: 70%;  border-radius: 50%;  transition: transform 0.5s;  
}  .img-fluid:hover {  transform: rotate(360deg);  
}  .bio, .career, .achievements, .teams, .personal-life {  background: rgba(34, 34, 34, 0.8);  color: #f0f0f0;  padding: 20px;  border-radius: 8px;  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);  
}  h1, h2 {  margin-top: 0;  
}  .list-group-item {  background: transparent;  color: #f0f0f0;  border: none;  
}  .footer {  background-color: #1a1a1a;  color: #f0f0f0;  text-align: center;  padding: 10px;  box-shadow: 0 -3px 8px rgba(0, 0, 0, 0.3);  
}

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

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

相关文章

25 基于51单片机的温度电流电压检测系统(压力、电压、温度、电流、LCD1602)

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于51单片机&#xff0c;通过DS18B20检测温度&#xff0c;滑动变阻器连接数模转换器模拟电流、电压&#xff0c;通过LCD1602显示&#xff0c;程序里设置温度阈值为40&#xff0c;电流阈值为60&am…

[大语言模型-论文精读] 以《黑神话:悟空》为研究案例探讨VLMs能否玩动作角色扮演游戏?

1. 论文简介 论文《Can VLMs Play Action Role-Playing Games? Take Black Myth Wukong as a Study Case》是阿里巴巴集团的Peng Chen、Pi Bu、Jun Song和Yuan Gao&#xff0c;在2024.09.19提交到arXiv上的研究论文。 论文: https://arxiv.org/abs/2409.12889代码和数据: h…

openKylin--安装 .net6.0

编辑profile文件 cd .. //切换到根目录 cd /etc //切换到etc目录 vim profile //b编辑profile文件 1. 按→键移动到文件末尾 2. 按Insert键进入编辑模式 3. 按Enter另起一行开始编辑 export DOTNET_ROOT/home/dotnetexport PATH$PATH:/home/dotnet 可以通过右键--粘贴 的…

【Rust练习】16.方法和关联函数

练习题来自&#xff1a;https://practice-zh.course.rs/method.html 1 &#x1f31f;&#x1f31f; 方法跟函数类似&#xff1a;都是使用 fn 声明&#xff0c;有参数和返回值。但是与函数不同的是&#xff0c;方法定义在结构体的上下文中(枚举、特征对象也可以定义方法)&#…

使用Crawler实例进行网页内容抓取

网页内容抓取的背景 随着互联网的快速发展&#xff0c;网页上的信息量日益庞大。如何从海量的网页中快速、准确地抓取所需信息&#xff0c;成为了一个技术挑战。网页内容抓取技术通过自动化的方式&#xff0c;模拟用户浏览网页的过程&#xff0c;获取网页上的文本、图片、链接…

简介图片生成大模型imagen

Imagen 是谷歌提出的一种基于文本描述生成高质量图像的大规模深度学习模型&#xff0c;其核心概念类似于DALLE等生成模型&#xff0c;但在架构和生成效果上做了创新。它通过结合大型语言模型&#xff08;例如 T5&#xff09;和扩散模型&#xff08;diffusion models&#xff09…

通信工程学习:什么是FDD频分双工

FDD:频分双工 FDD(频分双工,Frequency Division Duplexing)是一种无线通信技术,它通过将频谱划分为上行和下行两个不重叠的频段来实现同时双向通信。以下是FDD频分双工的详细解释: 一、定义与原理 定义: FDD是一种无线通信系统的工作模式,其中上行链路(从移动…

开源链动 2+1 模式 S2B2C 商城小程序:激活 KOC,开启商业新征程

摘要&#xff1a;本文深入探讨了 KOC 在立体连接中的重要性&#xff0c;以及如何通过开源链动 21 模式 S2B2C 商城小程序发现和找到更多的 KOC。强调了历史积累强关系和快速强化强关系的方法&#xff0c;并阐述了该商城小程序在推动商业发展中的关键作用。 一、引言 在当今竞争…

webpack4 target:“electron-renderer“ 打包加速配置

背景 昨天写得一篇Electron-vue asar 局部打包优化处理方案——绕开每次npm run build 超级慢的打包问题-CSDN博客文章浏览阅读754次&#xff0c;点赞19次&#xff0c;收藏11次。因为组员对于 Electron 打包过程存在比较迷糊的状态&#xff0c;且自己也没主动探索 Electron-vu…

Android常用C++特性之std::move

声明&#xff1a;本文内容生成自ChatGPT&#xff0c;目的是为方便大家了解学习作为引用到作者的其他文章中。 std::move 是 C11 引入的一个标准库函数模板&#xff0c;用于将对象转换为“右值引用”&#xff08;rvalue reference&#xff09;&#xff0c;从而允许移动语义&…

vue初学随笔

Vue基础 Vue基本概念 Vue是什么 Vue是一个渐进式的JavaScript框架&#xff0c;它基于标准 HTML、CSS 和 JavaScript 构建&#xff0c;并提供了一套声明式的、组件化的编程模型&#xff0c;帮助你高效地开发用户界面。 渐进式&#xff1a;各个特性可以根据项目需要逐渐引入和…

Linux中修改MySQL密码

Linux中MySQL的密码操作 1、给用户设置/更新密码 mysqladmin -u用户名 -p原密码 password "新密码"该命令在终端直接执行&#xff0c;不需要进入mysql视图 该命令适用于以下情况&#xff1a; 用户的密码为空&#xff0c;为用户设置密码用户密码需要更新&#xff0c…

数据库 - MySQL的事务

目录 前言 一、事务的特性 &#xff08;一&#xff09;原子性 &#xff08;二&#xff09;一致性 &#xff08;三&#xff09;隔离性 &#xff08;四&#xff09;持久性 二、事务的控制语句 三、事务隔离级别 &#xff08;一&#xff09;读未提交 &#xff08;二&…

2024 Fortinet OT工业安全高峰论坛成功举办

9月10日&#xff0c;“2024年Fortinet OT工业安全高峰论坛”于广州圆满闭幕。盛会紧扣“工业安全新行动&#xff0c;智驭AI新时代”主题&#xff0c;汇聚全球OT领域精英、技术先锋及安全领域翘楚&#xff0c;共谋OT现代化浪潮下的安全新篇章。通过多维度视角、深层次对话、鲜活…

C++ | Leetcode C++题解之第429题N叉树的层序遍历

题目&#xff1a; 题解&#xff1a; class Solution { public:vector<vector<int>> levelOrder(Node* root) {if (!root) {return {};}vector<vector<int>> ans;queue<Node*> q;q.push(root);while (!q.empty()) {int cnt q.size();vector<…

深圳锐明技术前端开发笔试题

目录 1. JavaScript 计算浏览器的刷新频率 2. 同源策略是什么&#xff1f;如何解决或避免浏览器同源请求和并发限制&#xff1f; 3. 数组分堆 4. 将一个数组对象改为树状结构 1. JavaScript 计算浏览器的刷新频率 实现计算浏览器刷新频率的思路如下&#xff1a; 使用浏览器…

Python_str(x)_x.str.something区别

str(x)&#xff1a; 这是一个Python内置函数&#xff0c;用于将对象x转换为字符串类型。 可以接受任何数据类型的对象作为输入&#xff08;如整数、浮点数、列表、元组等&#xff09;&#xff0c;并返回一个合理的字符串表示。 例&#xff1a;str(123) 会返回 ‘123’&#xff…

【AI学习】Lilian Weng:Extrinsic Hallucinations in LLMs(LLM 的外在幻觉)

来自OpenAI 的 Lilian Weng的《Extrinsic Hallucinations in LLMs》 Date: July 7, 2024 | Estimated Reading Time: 30 min | Author: Lilian Weng 文章链接&#xff1a;https://lilianweng.github.io/posts/2024-07-07-hallucination/ 大概看了一下&#xff0c;这篇文章的核…

深度学习与应用:行人跟踪

**实验 深度学习与应用&#xff1a;行人跟踪 ** ------ **1、 实验目的** ------ - 了解行人跟踪模型基础处理流程 - 熟悉行人跟踪模型的基本原理 - 掌握 行人跟踪模型的参数微调训练以及推理的能力 - 掌握行人跟踪模型对实际问题的应用能力&#xff0c;了解如何在特定的场景和…

机器学习及其应用领域【金融领域】

机器学习及其应用领域【金融领域】 一、智能投顾与资产配置二、信贷审批与风险评估三、支付与交易安全四、金融欺诈检测五、市场预测与情绪分析六、客户服务与个性化推荐七、面临的挑战与未来趋势八、总结 一、智能投顾与资产配置 智能投顾&#xff1a;通过机器学习技术&#…