java day23 CSS

1、CSS简介

1.1 什么是CSS

  • CSS :全称:Cascading Style Sheets 层叠样式表,定义如何显示HTML元素
  • 多个样式可以层层覆盖叠加,如果不同的css样式对同一html标签进行修饰,样式有冲突的
    应用优先级高的,不冲突的共同作用

1.2 CSS能干什么

  • 修饰美化html网页。
  • 外部样式表可以提高代码复用性从而提高工作效率。
  • html内容与样式表现分离,便于后期维护。

1.3 CSS书写规范

CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明

  • 选择器通常是您需要改变样式的 HTML 元素。
  • 每条声明由一个属性和一个值组成。

1.4 基础语法

选择器{属性:值;属性:值…… }

  • id选择器:
    • #news{
      margin-left: 24px;
      }
  • 类选择器:
    • .menu{
      float: left;
      margin-right: 31px;
      text-decoration: none;
      font:13px/23px Arial,sans-serif;
      }
  • 通配符选择器:
    • * {
      color: #00f;
      }
  • 标签选择器:
    • h1{
      color: red;
      }
      p{
      font-size: 50px;
      color: aquamarine;
      }
  • 属性选择器
    • p[name=“p1”][a=“p1”]{
      color: red;
      font-size: 22px;
      }
  • 派生选择器
    • ul li{
      color: red;
      }
  • 相邻选择器
    • li+li{
      color: red;
      }
  • 锚伪类选择器:
    • boby{
      background-color: red;
      }
      a:link{
      color: black;
      font-size: 15px;
      }
      a:hover{
      color: red;
      font-size: 20px;
      }
      a:active{
      color: greenyellow;
      }
      a:visited{
      color: darkorange;
      }

2、CSS导入方式

2.1 内嵌式(内联式)

把css样式嵌入html标签中

<p style="color: red">Mybatis是如何进行分页的?分页插件的原理是什么?</p>

2.2 内部式

在head标签中使用style标签引入css

<style type="text/css">
        span{
            color: blue;
        }
    </style>

2.3 外部式

将css样式抽成一个单独文件,使用者直接引用

<link href="../css/mycss.css" rel="stylesheet">

3、div盒子模型

在这里插入图片描述

3.1 边距

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--
        页面布局:
            table+css
            div+css
    -->
    <style type="text/css">
        #one{
            border:solid red 1px;
            /*内边距 内容与所有边框的距离*/
            /*padding: 10px;*/
            /*内容与左边框的距离*/
            padding-left: 10px;
        }
        #two{
            border: solid blue 1px;
            /*外边距 当前div与其他div边框的距离*/
            margin: 10px;
        }
        #three{
            border: solid green 1px;
        }
    </style>
</head>
<body>
    <div id="one">第一个盒子</div>
    <div id="two">第二个盒子</div>
    <div id="three">第三个盒子</div>
</body>
</html>

3.2 相对定位

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>02_相对定位</title>
    <style type="text/css">
        /*相对定位:相对于原有的位置进行改变,保留原来的位置,不影响其他div*/
        #one{
            border:solid red 1px;
        }
        #two{
            border: solid blue 1px;
            position: relative;
            left: 10px;
            top: 10px;
        }
        #three{
            border: solid green 1px;
        }
    </style>
</head>
<body>
    <div id="one">第一个盒子</div>
    <div id="two">第二个盒子</div>
    <div id="three">第三个盒子</div>
</body>
</html>

3.3 绝对定位

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>03_绝对定位</title>
    <style type="text/css">
        /*绝对定位:相对于拥有position属性的父标签进行定位,如果父标签没有position属性
                    继续往上寻找,如果一直没有,则相对于body定位*/
        #one{
            border:solid red 1px;
        }
        #two{
            border: solid blue 1px;
            /*绝对定位*/
            position: absolute;
            left: 0px;
        }
        #three{
            border: solid green 1px;
        }
    </style>
</head>
<body>
    <div id="one">1</div>
    <div id="two">2</div>
    <div id="three">3</div>
</body>
</html>

3.4 浮动

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>04_浮动</title>
    <style>
        #one{
            width: 100px;
            height: 100px;
            border: solid red 1px;
            float:left;
        }
        #two{
            width: 100px;
            height: 100px;
            border: solid blue 1px;
            float: right;
        }
        #three{
            width: 100px;
            height: 100px;
            border: solid green 1px;
        }
        /*清除浮动状态*/
        #clear{
            clear: both;
        }
    </style>
</head>
<body>
    <div id="one" >1</div>
    <div id="two">2</div>
    <div id="clear"></div>
    <div id="three">3</div>
</body>
</html>

案例展示

模仿百度首页

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>百度一下,你就知道</title>
    <link rel="icon" href="icon/baidu_logo.png" type="image/x-icon">
    <style type="text/css">
        .top_bar_left{
            float: left;
        }
        #news{
            margin-left: 24px;
        }
            .menu{
                 float: left;
                 margin-right: 31px;
                 text-decoration: none;
                 font:13px/23px Arial,sans-serif;
             }
        .menu1{
            float: left;
            margin-right: 25px;
            text-decoration: none;
            font:13px/23px Arial,sans-serif;
        }
        .menu2{
            position: absolute;
            right: 150px;
            float: left;
            margin-left: 2px;
        }
        .menu:hover{
            float: left;
            margin-right: 31px;
        }
        a{
            text-decoration: none;
            color: black;
        }
        a:hover{
            color: dodgerblue;
        }
        .top_bar_right{
            float: right;
        }
        #weather_pictures img{
            height: 23px;
            margin-right: 31px;
        }
        #temperature{
            margin-right: 45px;
        }
        #head_logo{
            border-radius: 50%;
            height: 23px;
        }

        .menu_name{
            position: relative;
            float: right;
            font:13px/23px Arial,sans-serif;
            margin-right: 10px;
        }
        .menu_name #username{
            padding-left: 10px;
        }

        #baidu_logo{
            position: relative;
            align-self: center;
            margin-left: 640px;
        }
        #baidu_logo img{
            height: 130px;
        }
        #middle{
            padding-top: 40px;
        }
        #serach_input{
            height: 16px;
            width: 520px;
            padding: 12px 16px;
            font-size: 16px;
            vertical-align: top;
            outline: 0;
            box-shadow: none;
            border-radius: 10px 0 0 10px;
            border: 2px solid #c4c7ce;
            background: #fff;
            color: #222;
            overflow: hidden;
            box-sizing: content-box;
            margin-left: 440px;
        }
        #baidu_search{
            cursor: pointer;
            width: 108px;
            height: 44px;
            line-height: 45px;
            line-height: 44px\9;
            padding: 0;
            background-color: #4e6ef2;
            border-radius: 0 10px 10px 0;
            font-size: 17px;
            color: #fff;
            box-shadow: none;
            font-weight: 400;
            border: none;
            outline: 0;
            text-align: center;
        }
        .search{
            margin-top: 10px;
        }
        .bar{
            margin-top: 100px;
            margin-left: 250px;
            padding-bottom: 10px;
        }
        .bar a{
            margin-right: 15px;
        }
        .title{
            margin-left: 250px;
            font: 20px/30px Arial,sans-serif;
            padding-bottom: 10px;
        }
        .new_img{
            margin-left: 250px;

        }
        #new_img img{
            border-radius: 10px;
        }
        .news_left{
            float: left;
            width: 800px;

        }
        .news_right{
            float: right;
        }

        .bar_right{
            margin-top: 100px;
        }
        .bar_right a{
            position: relative;
            margin-right: 270px;
        }
        .counts{
            float: right;
            margin-right: 275px;
        }
        .number{
            padding-right: 20px;
        }
        p{
            font: 15px Arial,sans-serif;
        }
    </style>
</head>
<body>
<div id="top">
    <div class="top_bar_left">
        <a href="#" class="menu" id="news">新闻</a>
        <a href="#" class="menu" id="hao123">hao123</a>
        <a href="#" class="menu" id="maps">地图</a>
        <a href="#" class="menu" id="video">视频</a>
        <a href="#" class="menu" id="postbar">贴吧</a>
        <a href="#" class="menu" id="study">学术</a>
        <a href="#" class="menu" id="more">更多</a>
    </div>

    <div class="top_bar_right">
        <div class="menu1"><a href="#" id="guangzhou">广州</a></div>
        <a href="#">
            <div class="menu1" id="weather_pictures"><img src="icon/a1.png"></div>
            <div class="menu2" id="temperature"><a href="#" >19°C</a></div>
        </a>
        <div class="menu1"><a href="#" >设置</a></div>
        <div class="menu1">
            <a href="#"><img id="head_logo" src="icon/touxiang.jpg"></a>
            <div class="menu_name">
                <a href="#" id="username">岁月如歌</a>
            </div>
        </div>
    </div>
</div>
<div id="middle">
    <div id="baidu_logo" ><img src="icon/baidu.png"></div>
    <div class="search"><input id="serach_input" ><input type="button" id="baidu_search" value="百度一下"></div>
</div>


<div id="bottom_news">
        <div class="news_left">
            <div class="bar">
                <a href="#">我的关注</a>
                <a href="#">推荐</a>
                <a href="#">导航</a>
            </div>
            <div class="title">荣耀V40再曝支持45W无线充;小米11发布时间确定没有Pro?</div>
            <div class="new_img"> <img src="icon/newphoto.png"> </div>
        </div>


        <div class="news_right">
            <div class="bar_right">
                <a href="#">百度热榜</a>
                <a href="#">换一换</a>
            </div>
            <div class="specific_news">
                <p>
                    <span class="number">1</span>
                    <span class="new_title"><a href="#">美舰擅闯南沙海域 中方警告驱离</a></span>
                    <span class="counts"><a href="#">483万</a></span>
                </p>

                <p>
                    <span class="number">2</span>
                    <span class="new_title"><a href="#">检方认为劳荣枝主观恶性极深</a></span>
                    <span class="counts"><a href="#">466万</a></span>
                </p>
</a>
                <p>
                    <span class="number">3</span>
                    <span class="new_title"><a href="#">大连:开展全员核酸检测</a></span>
                    <span class="counts"><a href="#">450万</a></span>
                </p>

                <p>
                    <span class="number">4</span>
                    <span class="new_title"><a href="#">18岁大学生立遗嘱财产留给朋友</a></span>
                    <span class="counts"><a href="#">411万</a></span>
                </p>

                <p>
                    <span class="number">5</span>
                    <span class="new_title"><a href="#">大连海洋大学出现疫情?校方回应</a></span>
                    <span class="counts"><a href="#">383万</a></span>
                </p>

                <p>
                    <span class="number">6</span>
                    <span class="new_title"><a href="#">杜海涛删除二手平台已售宝贝</a></span>
                    <span class="counts"><a href="#">369万</a></span>
                </p>

            </div>
        </div>
</div>
</body>
</html>

效果:
在这里插入图片描述

Java中创建一个课表,并使用CSS美化可以分为两个部分:数据结构和UI设计。首先,我们创建一个简单的Java类来表示课程,然后使用HTMLCSS来展示这个课表。 1. 数据模型:定义一个`Course`类,包含属性如课程名、教师、时间和地点等。示例代码如下: ```java public class Course { private String courseName; private String teacher; private LocalTime time; private String location; // getters and setters } ``` 2. 创建课表列表:使用Java集合(例如ArrayList或LinkedList)存储课程实例,然后遍历它们生成HTML字符串。 ```java List<Course> courses = ...; // 初始化课程列表 StringBuilder htmlBuilder = new StringBuilder(); htmlBuilder.append("<table class='schedule'>"); for (Course course : courses) { htmlBuilder.append("<tr>"); htmlBuilder.append("<td>" + course.getCourseName() + "</td>"); htmlBuilder.append("<td>" + course.getTeacher() + "</td>"); htmlBuilder.append("<td>" + course.getTime().toString() + "</td>"); htmlBuilder.append("<td>" + course.getLocation() + "</td>"); htmlBuilder.append("</tr>"); } htmlBuilder.append("</table>"); String scheduleTable = htmlBuilder.toString(); ``` 3. 使用CSS美化:创建一个`.schedule`的CSS样式,包括颜色、字体、边距等,为课表添加美观的外观。例如: ```css .schedule { border-collapse: collapse; width: 80%; margin: auto; } .schedule th, .schedule td { padding: 10px; text-align: left; border-bottom: 1px solid #ddd; } .schedule th { background-color: #f2f2f2; font-weight: bold; } .day { color: #666; } .location { color: #999; } ``` 将HTMLCSS合并到一起,你就得到一个简单的Java课表了。记得将实际的课程数据填充到`courses`列表中。如果你需要更复杂的功能,比如搜索、排序等,也可以根据需求进行扩展。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值