前端代码基础

简介: 前端代码基础

引言

此文为html+css+JavaScript的项目实战,是全栈开发的前端基础,这项基础会持续到ssm框架后进行拓展至mpvue,vue3,uniapp,React.

下面主要实现为使网页更加美观我们先进行两个基础实战,渐变背景和轮播图,最后进行一个项目实战做一个简单的前端网站


实战一:渐变背景

这个为css文件,可以加入任意css文件中设置渐变背景,颜色可以进行更改,下面有代码详解,帮助二次开发

*{
  margin: 0;
  padding: 0;
}
body{
  font-family: "monotype corsiva";
  background-image: linear-gradient(125deg,#2c3e50,#27ae60,#2980b9,#e74c3c);
  background-size: 400%;
  animation:jb 15s infinite;
}
.text{
  color: white;
  text-align: center;
  text-transform: uppercase;
  margin: 300px 0;
  font-size: 22px;
}
@keyframes jb{
  0%{
    background-position: 0% 50%;
  }
  50%{
    background-position: 100% 50%;
  }
  100%{
    background-position: 0% 50%;
  }|
}

代码分析:


这是一个CSS样式代码片段,它描述了一个网页的背景渐变色、字体样式、文字颜色和动画效果。具体解释如下:


第一行 *{ margin: 0; padding: 0; } 表示将所有HTML标签的外边距和内边距设置为0,这是初始化页面样式的常见做法。

body{ ... } 表示组合选择器,下面的代码块描述了 body 标签的样式,其中:

font-family: "monotype corsiva"; 表示使用"monotype corsiva"字体,用于设置页面中所有字体的样式。

background-image: linear-gradient(125deg,#2c3e50,#27ae60,#2980b9,#e74c3c); 表示使用 linear-gradient 属性创建一个从左上角到右下角的渐变背景色,并设置了四个颜色值,参与渐变的颜色范围。颜色值以逗号分隔。

background-size: 400%; 表示设置背景图片大小为父元素的400%。

animation:jb 15s infinite; 表示将动画效果应用于 jb 关键帧,动画播放时间为15秒,重复播放无限次。

.text{ ... } 表示类选择器,下面的代码块描述了 .text 类的样式,其中:

color: white; 表示文字颜色为白色。

text-align: center; 表示文字居中对齐。

text-transform: uppercase; 表示将文字转换为全大写。

margin: 300px 0; 表示文字的上下边距为300像素。

font-size: 22px; 表示文字大小为22像素。

@keyframes jb{ ... } 表示定义一个名为 jb 的关键帧动画,其中:

0%{ ... } 表示动画开始时的状态。

50%{ ... } 表示动画播放到一半时的状态。

100%{ ... } 表示动画结束时的状态。

background-position: 0% 50%; 表示背景图片位置,第一个值表示水平方向位置,第二个值表示垂直方向位置。在这个动画中,背景图片的位置会从左到右不断变化,最终回到初始位置。

资源下载连接地址:链接: link

实战二:轮播图

轮播图为小项目,可以放到页面顶页或index页面进行二次开发,下面介绍两种轮播图,下面为css文件

轮播图(1)

* {
  /* 初始化 取消页面的内外边距 */
  padding: 0;
  margin: 0;
  /* 盒子模型 */
  box-sizing: border-box;
}
body {
  /* 弹性布局 让页面元素垂直+水平居中 */
  display: flex;
  justify-content: center;
  align-items: center;
  /* 让页面始终占屏幕总高 */
  height: 100vh;
}
.swiper {
  /* 相对定位 */
  position: relative;
  width: 857px;
  height: 441px;
  overflow: hidden;
}
input {
  display: none;
}
label {
  position: absolute;
  bottom: 30px;
  width: 20px;
  height: 20px;
  border: 3px solid #fff;
  border-radius: 50%;
  background-color: #fff;
}
label[for="btn1"] {
  left: 35%;
}
label[for="btn2"] {
  left: 40%;
}
label[for="btn3"] {
  left: 45%;
}
label[for="btn4"] {
  left: 50%;
}
label[for="btn5"] {
  left: 55%;
}
label[for="btn6"] {
  left: 60%;
}
label[for="btn7"] {
  left: 65%;
}
ul {
  /* 让li水平排列 */
  display: flex;
  /* 自动计算宽度 */
  width: calc(857px * 7);
  /* 过渡时间 */
  transition: all 0.5s;
}
li {
  list-style-type: none;
}
#btn1:checked ~ ul {
  margin-left: 0;
}
#btn2:checked ~ ul {
  margin-left: -857px;
}
#btn3:checked ~ ul {
  margin-left: calc(-857px * 2);
}
#btn4:checked ~ ul {
  margin-left: calc(-857px * 3);
}
#btn5:checked ~ ul {
  margin-left: calc(-857px * 4);
}
#btn6:checked ~ ul {
  margin-left: calc(-857px * 5);
}
#btn7:checked ~ ul {
  margin-left: calc(-857px * 6);
}
#btn1:checked ~ label[for="btn1"] {
  background-color: #f00;
}
#btn2:checked ~ label[for="btn2"] {
  background-color: #f00;
}
#btn3:checked ~ label[for="btn3"] {
  background-color: #f00;
}
#btn4:checked ~ label[for="btn4"] {
  background-color: #f00;
}
#btn5:checked ~ label[for="btn5"] {
  background-color: #f00;
}
#btn6:checked ~ label[for="btn6"] {
  background-color: #f00;
}
#btn7:checked ~ label[for="btn7"] {
  background-color: #f00;
}


该轮播图为自己点击切换,设置好图片信息即可

代码详解:


这段代码是实现一种轮播图效果的CSS样式代码,具体实现过程如下:


给所有元素的内外边距设置为0,盒子模型设置为border-box,保证元素的宽高不会因为边框和内边距而发生变化。

给body元素设置display属性为flex,通过justify-content和align-items属性实现页面元素的垂直和水平居中,同时通过height属性让页面始终占据屏幕总高度。

给轮播图.swiper元素设置position属性为relative,为子元素提供定位的参考点,同时设置宽度和高度,overflow属性为hidden,让超出部分隐藏。

给input元素设置display属性为none,让其在页面中不可见。

给label元素设置position属性为absolute,bottom属性为30px,使其在轮播图的底部,并通过left属性设置每个按钮的位置。

给ul元素设置display属性为flex,让li元素水平排列,width属性设置为7个轮播图的总宽度,transition属性设置过渡时间。

给li元素设置list-style-type属性为none,去掉li元素的默认样式。

对7个轮播图分别设置:checked伪类,每个伪类对应一个label元素和ul元素的样式,通过margin-left属性实现轮播图的切换,同时通过background-color属性控制哪个按钮处于选中状态。

这段代码实现的轮播图效果是通过7个单选框和7个label元素控制图片的切换,通过CSS伪类:checked控制轮播图的位置,同时通过label元素的背景色标示哪张图片处于选中状态。

资源下载地址:链接: link

轮播图(2)

改轮播图为自动轮播,可以通过鼠标控制轮播图的暂停与开始或者跳转,只需设置一个 .js 文件即可,下面为css文件

*{
  margin: 0;
  padding:0;
}
body{
  position: absolute;
  width: 100%;
  height: 100%;
  perspective:2000px;
}
.back{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
}
h1{
  position: relative;
  top:100px;
  color: white;
  text-align: center;
  font-family: "微软雅黑";
  font-size: 50px;
  z-index: 999;
}
.section{
  position:absolute;
  width: 300px;
  height: 300px;
  transform-style: preserve-3d;
  margin: 200px auto;
  top:10%;
  left: 40%;
  animation: rotate 5s linear infinite;
  z-index: 999;
}
.section div{
  position: absolute;
  width: 300px;
  height: 300px;
  border-radius: 30px;
  font-family: "微软雅黑";
  font-size: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.section:hover{
  animation-play-state: paused;
}
@keyframes rotate{
  0%{
    transform: rotateY(0);
  }
  100%{
    transform: rotateY(360deg);
  }
}
.section div:nth-child(1){
  transform: rotateY(60deg) translateZ(300px);
  background:url(../img/be297bc5ly1gjlx659lprj20jg0jg18a.jpg) no-repeat;
}
.section div:nth-child(2){
  transform: rotateY(120deg) translateZ(300px);
  background:url(../img/be297bc5ly1gkl0cpboyhj20jg0jg195.jpg) no-repeat;
}
.section div:nth-child(3){
  transform: rotateY(180deg) translateZ(300px);
  background: white;
  background: url(../img/be297bc5ly1gkl0cpsrixj20jg0jgnbw.jpg) no-repeat;
}
.section div:nth-child(4){
  transform: rotateY(240deg) translateZ(300px);
  background: url(../img/be297bc5ly1gkl0cqpmuvj20jg0jgnbs.jpg) no-repeat;
}
.section div:nth-child(5){
  transform: rotateY(300deg) translateZ(300px);
  background: url(../img/be297bc5ly1gkl0cqbgghj20jg0jg7jz.jpg) no-repeat;
}
.section div:nth-child(6){
  transform: rotateY(360deg) translateZ(300px);
  background: url(../img/be297bc5ly1gkl0cr6d1ij20jg0jg4b4.jpg) no-repeat;
}

代码解释

这是一个CSS代码,用于创建一个带有不同图像的三维旋转立方体。该立方体位于屏幕中心,并无限旋转。当鼠标悬停在其上方时,动画会暂停。 以下是代码功能的详细解释:


将页面上所有元素的边距和内边距设置为0。

将透视设置为2000px,以创建三维效果。

定义一个覆盖整个屏幕的背景元素。

在页面上方定义一个带有文本的h1元素。

定义一个section元素,其中包含六个div元素,每个表示立方体的一个面。

将transform-style设置为preserve-3d,以维持3D效果。

对section元素应用rotate动画,以旋转立方体。

对每个div元素定义一个背景图像,并应用transform来使用rotateY和translateZ属性将其定位在立方体面上。

当鼠标悬停在section元素上方时,动画暂停。

你可以使用此代码创建带有自己的图像的旋转立方体,或修改它以适应你的需求。具体成果:


资源下载地址:链接: link

实战三:简单的综合应用

插画展示平台,使用了html+css+JavaScript综合应用以及表单的使用

主要代码为

html:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="css/hldt.css" />
    <script>
      window.onload=function(){
      var oul=document.getElementById("ul1");
      window.setInterval(function(){
        oul.appendChild(oul.children[0]);
        },800)
      }
    </script>
  </head>
  <body>
    <header class="header">
      <div class="head">
      <img src="img/logo.png" class="logo"/>
        <strong class="elegant">插画</strong>
        <div class="btn">
          <div class="yy"><a href="index.html">网站首页</a></div>
          <div class="yyx"><a href="#">画廊动态</a></div>
          <div class="yy"><a href="hlzs.html">画廊展示</a></div>
          <div class="yy"><a href="lxfs.html">联系方式</a></div>
        </div>
        <div class="by">
          <div class="banner">
            <span class="text1">水彩是一种清淡,优美的绘画材料,色彩纯度偏低,绘画效果多变,具有一定随机性。<br />
               调色方便,目前越来越受到广大艺术家欢迎。<br /> 
               在Elegant里,水彩是我们的主要创作材料。让我们通过它,带给你更加新奇的视觉享受。 
            </span>
          </div>
          <div class="lst">
            <ul class="lst-wrap" id="ul1">
              <li href="#"><img src="img/11.jpg" class="photo"></li>
              <li href="#"><img src="img/33.jpg" class="photo"></li>
              <li href="#"><img src="img/22.jpg" class="photo"></li>
            </ul>
          </div>
        </div>
        <div class="bottom">
        <span>
          雪碧有白泡泡<br />  
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;qq <br />
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;联系方式
        </span>
      </div>
      </div>
    </header>
  </body>
</html>
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="css/hlzs.css" />
  </head>
  <body>
    <header class="header">
      <div class="head">
      <img src="img/logo.png" class="logo"/>
        <strong class="elegant">插画</strong>
        <div class="btn">
          <div class="yy"><a href="index.html">网站首页</a></div>
          <div class="yy"><a href="hldt.html">画廊动态</a></div>
          <div class="yyx"><a href="#">画廊展示</a></div>
          <div class="yy"><a href="lxfs.html">联系方式</a></div>
        </div>
        <div class="by">
          <div class="lst">
            <ul class="lst-wrap">
              <li><a href="#"><img src="img/1.jpg"</a></li>
              <li><a href="#"><img src="img/2.jpg"</a></li>
              <li><a href="#"><img src="img/3.jpg"</a></li>
              <li><a href="#"><img src="img/4.jpg"</a></li>
            </ul>
          </div>
      </div>
      <div class="bottom">
        <span>
          雪碧有白泡泡<br />  
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;qq<br />
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;联系方式
        </span>
      </div>
      </div>
  </body>
</html>
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title></title>
    <link rel="stylesheet" href="css/index.css" />
  </head>
  <body>
    <header class="header">
      <div class="head">
      <img src="img/logo.png" class="logo"/>
        <strong class="elegant">插画</strong>
        <div class="btn">
          <div class="yyx"><a href="#">网站首页</a></div>
          <div class="yy"><a href="hldt.html">画廊动态</a></div>
          <div class="yy"><a href="hlzs.html">画廊展示</a></div>
          <div class="yy"><a href="lxfs.html">联系方式</a></div>
        </div>
        <div class="by">
          <div class="banner">
            <span class="text1">最具活力的画坛信-息集散地  </span>
            <span class="text2">最权威的造型艺术展示平台 </span>
          </div>
          <strong><span class="zxdt">最新动态</span></strong>
          <div class="xw">
            <strong><span>—插画 </span></strong><br />
            <strong><span>插画 </span></strong><br />
            <strong><span>插画 </span></strong>
          </div>
      </div>
      <div class="bottom">
        <span>
          雪碧有白泡泡<br />  
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;qq <br />
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;联系方式
        </span>
      </div>
      </div>
    </header>
  </body>
</html>
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="css/lxfs.css" />
    <script>
      window.onload=function{
      }
    </script>
  </head>
  <body>
      <header class="header">
      <div class="head">
      <img src="img/logo.png" class="logo"/>
        <strong class="elegant">插画</strong>
        <div class="btn">
          <div class="yy"><a href="index.html">网站首页</a></div>
          <div class="yy"><a href="hldt.html">画廊动态</a></div>
          <div class="yy"><a href="hlzs.html">画廊展示</a></div>
          <div class="yyx"><a href="#">联系方式</a></div>
        </div>
        <div class="by">
          <form class="form1">
            <p>姓名:<input type="text" name="username" size="30"/></p>
            <p>职业:<input type="text" name="zhiye" size="30"/></p>
            <p>
              联系目的:<input type="radio" name="radio1" />加入我们
              <input type="radio" name="radio1" />购买插画
              <input type="radio" name="radio1" />展示插画
              <input type="radio" name="radio1" />其他
            </p>
            <p>联系电话:<input type="text" name="lxdh" size="25"/></p>
            <span class="zj">注解:</span>
            <input type="text" class="txt"></input>
            </span>
          </form>
      </div>
      <div class="bottom">
        <span>
          雪碧有白泡泡<br />  
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; qq <br />
          &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;联系方式
        </span>
      </div>
      </div>
      qq
    </header>
  </body>
</html>

具体成果展示

资源下载地址:链接: link

相关文章
|
23天前
|
JavaScript 前端开发 Docker
前端全栈之路Deno篇(二):几行代码打包后接近100M?别慌,带你掌握Deno2.0的安装到项目构建全流程、剖析构建物并了解其好处
在使用 Deno 构建项目时,生成的可执行文件体积较大,通常接近 100 MB,而 Node.js 构建的项目体积则要小得多。这是由于 Deno 包含了完整的 V8 引擎和运行时,使其能够在目标设备上独立运行,无需额外安装依赖。尽管体积较大,但 Deno 提供了更好的安全性和部署便利性。通过裁剪功能、使用压缩工具等方法,可以优化可执行文件的体积。
前端全栈之路Deno篇(二):几行代码打包后接近100M?别慌,带你掌握Deno2.0的安装到项目构建全流程、剖析构建物并了解其好处
|
5天前
|
前端开发 JavaScript
前端界的革命:掌握这些新技术,让你的代码简洁到让人惊叹!
前端技术的快速发展带来了许多令人惊叹的新特性。ES6及其后续版本引入了箭头函数、模板字符串等简洁语法,极大减少了代码冗余。React通过虚拟DOM和组件化思想,提高了代码的可维护性和效率。Webpack等构建工具通过模块化和代码分割,优化了应用性能和加载速度。这些新技术正引领前端开发的革命,使代码更加简洁、高效、可维护。
11 2
|
5天前
|
前端开发 JavaScript 测试技术
前端工程师的必修课:如何写出优雅、可维护的代码?
前端工程作为数字世界的门面,编写优雅、可维护的代码至关重要。本文从命名规范、模块化设计、注释与文档、遵循最佳实践四个方面,提供了提升代码质量的方法。通过清晰的命名、合理的模块划分、详细的注释和持续的学习,前端工程师可以写出高效且易于维护的代码,为项目的成功打下坚实基础。
14 2
|
11天前
|
监控 前端开发 JavaScript
前端开发的终极奥义:如何让你的代码既快又美,还不易出错?
【10月更文挑战第31天】前端开发是一个充满挑战与机遇的领域,本文从性能优化、代码美化和错误处理三个方面,探讨了如何提升代码的效率、可读性和健壮性。通过减少DOM操作、懒加载、使用Web Workers等方法提升性能;遵循命名规范、保持一致的缩进与空行、添加注释与文档,让代码更易读;通过输入验证、try-catch捕获异常、日志与监控,增强代码的健壮性。追求代码的“快、美、稳”,是每个前端开发者的目标。
27 3
|
12天前
|
前端开发 JavaScript 开发者
前端开发的终极技巧:如何让你的代码既简洁又高效,还能减少bug?
【10月更文挑战第30天】前端开发充满挑战与创新,如何编写简洁高效且少bug的代码是开发者关注的重点。本文介绍五大技巧:1. 模块化,提高代码复用性;2. 组件化,降低代码耦合度;3. 使用现代框架,提高开发效率;4. 统一代码规范,降低沟通成本;5. 利用工具,优化代码质量。掌握这些技巧,让前端开发更高效。
27 1
|
19天前
|
前端开发 JavaScript 开发者
揭秘前端高手的秘密武器:深度解析递归组件与动态组件的奥妙,让你代码效率翻倍!
【10月更文挑战第23天】在Web开发中,组件化已成为主流。本文深入探讨了递归组件与动态组件的概念、应用及实现方式。递归组件通过在组件内部调用自身,适用于处理层级结构数据,如菜单和树形控件。动态组件则根据数据变化动态切换组件显示,适用于不同业务逻辑下的组件展示。通过示例,展示了这两种组件的实现方法及其在实际开发中的应用价值。
27 1
|
1月前
|
前端开发 JavaScript 开发者
利用代码分割优化前端性能:高级技巧与实践
【10月更文挑战第2天】在现代Web开发中,代码分割是优化前端性能的关键技术,可显著减少页面加载时间。本文详细探讨了代码分割的基本原理及其实现方法,包括自动与手动分割、预加载与预取、动态导入及按需加载CSS等高级技巧,旨在帮助开发者提升Web应用性能,改善用户体验。
|
1月前
|
前端开发 小程序 JavaScript
信前端里的循环显示如何编写代码?
信前端里的循环显示如何编写代码?
69 5
|
3月前
|
缓存 前端开发 数据格式
构建前端防腐策略问题之保证组件层的代码不受到接口版本变化的问题如何解决
构建前端防腐策略问题之保证组件层的代码不受到接口版本变化的问题如何解决
|
3月前
|
JavaScript 前端开发 小程序
【技巧】JS代码这么写,前端小姐姐都会爱上你
本文介绍了JavaScript编程中的实用技巧,包括解构赋值的多种妙用、数组操作技巧及常用JS功能片段。解构赋值部分涵盖短路语法防错、深度解构及默认值赋值;数组技巧包括按条件添加数据、获取最后一个元素及使用`includes`优化`if`语句;常用功能片段则涉及URL参数解析、页面滚动回顶部及获取滚动距离等。通过这些技巧,提升代码质量和效率。
31 0
【技巧】JS代码这么写,前端小姐姐都会爱上你