2021-11-08周报

目录

一、前端

1.css三大特性:

1.层叠性

2.继承性 

3.优先级

2.css盒子模型

1.边框border

2.内边距padding

3.外边距margin

二、python学习


一、前端

1.css三大特性:

层叠性,继承性,优先级

1.层叠性

层叠性:给相同的选择器设置相同的样式,样式会覆盖到最新的

​
<style>
        div{
            color: aqua;
        }
        div{
            color: brown;
        }

​

 

2.继承性 

继承性:孩子会继承父亲的样式

合理的使用可以简化代码

子元素可以继承父元素的样式(text-,font-,line-以及color属性)

<style>
        div {
            color: pink;
            font-size: 14px;
        }
    </style>


<body>
    <div>
        <p> 123456</p>
    </div>

</body>

行高的继承性

<style>
        body {
            color: pink;
            font: 12px/1.5 'Microsoft YaHei';
        }
        div{
            font-size: 14px;
            /* 行高为14*1.5px */
        }
        p{
            font-size: 16px;
            /* 行高为16*1.5px */
        }
    </style>


<body>
    <div>粉红色</div>
    <p>粉红色</p>
    <ul>
        <li>没有指定文字大小</li>
        <!-- li没有指定文字大小,继承父亲的文字大小 -->
        <!-- 所以li的文字大小为12px,行高为12*1.5px -->
    </ul>

</body>

行高可以带单位,也可以不带单位

不带单位:1.5表示当前元素文字大小的1.5倍

3.优先级

同一个元素指定多个选择器,就会有优先级

选择器相同,执行层叠性

选择器不同,根据选择器权重执行

选择器权重有小到大:1.继承或者*;2.元素选择器;3.类选择器,伪类选择器;4.ID选择器;5.行内样式style;6.!important

div {
            color: pink !important;
            /* 权重:0,0,0,0 */
        }

        .test {
            color: red;
            /* 权重:0,0,1,0 */
        }

        #demo {
            color: green;
            /* 权重:0,1,0,0 */
        }

        body {
            color: red;
        }

        a {
            color: green;
        }


<body>
    <div class="test" id="demo" style="color: purple;">
        <!-- 行内样式表权重:1,0,0,0 -->
        123
    </div>
    <!-- 依次是类选择器,ID选择器,行内样式表style -->
    <!-- 对元素选择器加!important ,这样元素选择器的权重就最大了-->
    <!-- 继承的权重是0,0,0,0,只要选择器选中了元素,就比继承优先 -->
    <!-- 即使继承加上!important,也没有选出来的样式优先级高 -->
    <a href="#">我是单独的样式</a>
    <!-- a链接:浏览器默认指定了一个样式(蓝色,有下划线) -->

</body>

 

css权重叠加问题:

 <style>
        li {
            color: red
        }

        ul li {
            color: green;
        }

        /* 复合选择器涉及权重叠加问题 */
        /* 权重会叠加,但是不会进位 */
        /* 权重是从左往右依次对比优先级 */

        /* li的权重是0,0,0,1 */
        /* ul li的权重是0,0,0,1+0,0,0,1 =0,0,0,2*/

        .nav li {
            color: pink;
        }

        /* .nav li的权重是0,0,1,0+0,0,0,1=0,0,1,1 */
    </style>


</head>

<body>
    <ul class="nav">
        <li>1</li>
        <li>2</li>
        <li>3</li>
    </ul>

</body>

 

2.css盒子模型

网页布局过程:

1.先准备好相关页面元素,页面元素基本都是盒子

2.利用css设置好盒子样式,然后摆放到相应位置

3.往盒子里面装内容

网页布局的核心本质:利用css摆放盒子

css盒子模型本质上是一个盒子,封装周围的html元素,它包括:border边框,content内容,padding内边距,margin外边距

 

1.边框border

border可以设置元素的边框,由三部分组成:边框宽度,边框样式,边框颜色

<style>
        div {
            width: 300px;
            height: 200px;
            /* 
            border-width: 5px;
            border-color: blue;
            border-style: dotted;
             */
            /* 边框样式:solid:实线边框 dashed:虚线边框 dotted:点线边框 */


            /* 边框简写:(没有顺序) */
            /* border:1px solid black; */

            /* 边框分开写法 (四条边)*/
            border-top: 5px solid pink;
            border-bottom: 5px dashed blue;


        }
    </style>
</head>

<body>
    <div>123</div>

</body>

表格边框的粗细问题:

两个相邻表格,如果都设置了边框宽度,那么实际的边框宽度就是设置的两个宽度之和,这就需要合并边框宽度。

border-collapse:collapse

<style>
        table {
            width: 500px;
            height: 250px;

        }

        table,
        td {
            border: 1px solid pink;
            /* border-collapse: 控制相邻单元格的边框 */
            border-collapse: collapse;
            /* 表示相邻边框合并在一起 */
            font-size: 14px;
            text-align: center;
        }
    </style>

边框对盒子实际大小的影响:

盒子边框会使盒子变大,如果测量时候包括边框,设置盒子大小就要用盒子实际大小-边框宽度

2.内边距padding

内边距:设置盒子边框和内容之间的距离

        div{
            width: 200px;
            height: 200px;
            background-color: pink;
            /* 
            padding-top: 10px;
            padding-left: 10px;
             */

            /* padding的复合写法 */
            /* padding:5px */
            /* 上下左右都有5像素内边距 */
            /* padding:5px 10px */
            /* 上下5像素内边距,左右10像素内边距 */
            /* padding:5px 10px 20px */
            /* 上5,左右10,下20 */
            /* padding:5px 10px 20px 30px */
            /* 上5 右10 下20 左30(顺时针方向) */
            /* 四种方法都需要记住 */

            padding: 20px;
            /* 内边距也会影响盒子的实际大小 */
            /* 盒子实际大小=盒子设置宽度+内边距大小 */
            
        }


    </style>
</head>
<body>
    <div>
        盒子内容盒子内容盒子内容盒子内容盒子内容盒子内容

    </div>
    
</body>

padding不会撑开盒子的情况:

如果盒子没有指定width/heights属性,此时padding不会撑开盒子的宽度/高度。

<style>
        h1 {
            background-color: pink;
            padding: 30px;
        }

        div{
            width: 300px;
            height: 100px;
            background-color: purple;
        }
        div p{
            padding: 30px;
        }
    </style>


</head>

        <p>
            123
        </p>
    </div>

</body>

通常情况下,不会继承宽和高,但是块元素可以继承父标签的宽度,属于特例

父标签有宽度,子标签有内边距,子标签padding也不会撑开盒子的宽度

3.外边距margin

    <style>
        div {
            background-color: pink;
            width: 200px;
            height: 200px;
        }

        .one {
            /* margin: 20px; */
            /* margin:5px 10px;
            上下5 左右10 */
            /* margin:5px 10px 20px
            上5 左右10 下20 */
            margin: 5px 10px 20px 30px
                /* 顺时针,上右下左 */

        }
    </style>
</head>

<body>
    <div class="one">
        1
    </div>
    <div class="two">
        2
    </div>

</body>

设置的方法与padding一样。

外边距的应用:块级盒子水平居中对齐

    <style>
        .header{
            width: 900px;
            height: 200px;
            background-color: pink;
            margin: auto;
            /* margin: 0 auto; 上下外边距0,左右外边距auto (最常使用) */
            /* margin-left: auto;margin-right: auto; */
            /* 上面三种写法都可以 */
            text-align:center;
        }

    </style>
</head>
<body>
    <div class="header">
        <span>里面的文字</span>
    </div>    
</body>

想要让块级盒子水平居中,必须满足两个条件:

1.盒子必须指定了宽度。2.盒子左右的外边距都设置为auto

这种方法对行内元素和行内块元素是无效的。

行内元素或者行内块元素水平居中:给其父元素添加text-align:center(把它们看做是文字)

外边距margin合并的两种情况

问题1:相邻块元素垂直外边距的合并

    <style>
        .damao,.ermao{
            width: 200px;
            height: 200px;
            background-color: pink;
        }
        .damao{
            margin-bottom: 100px;
        }
        .ermao {
            margin-top: 200px;
        }

        /* 
    </style>


<body>
    <div class="damao">大毛</div>
    <div class="ermao">二毛</div>
</div>

</body>

实际上,两个盒子之间的距离只有200px,而不是100+200px。这就是外边距合并。

如果上下相邻的两个块元素(兄弟关系)相遇时,上面元素有下外边距,下面元素有上外边距。那么它们之间的垂直距离不是两个外边距之和,而是两个外边距中较大的那个,这种现象叫做相邻块元素垂直外边距的合并。

解决方法,只给一个盒子添加margin。

问题2:嵌套块元素塌陷

对于两个嵌套关系(父子关系)的块元素,父元素有上外边距同时子元素也有上外边距, 此时父元素会塌陷较大的外边距。

<style>
        .father{
            width: 400px;
            height: 400px;
            background-color: purple;
            margin-top: 50px;
            /* 解决方法1 */
            /* border:1px solid transparent */
            /* 解决方法2 */
            /* padding: 1px; */
            /* 解决方法3 */
            overflow:hidden
        }

        .son{
            width: 200px;
            height: 200px;
            background-color: pink;
            margin-top: 100px;
        }

</style>

<body>

    <div class="father">
        <div class="son"></div>
    </div>

</body>

例子:

父元素有上外边距50px,子元素有上外边距100px。

(塌陷后)实际情况父元素和子元素都会有上外边距100px。

解决方案:

1.为父元素定义上边框

2.为父元素定义上内边距

3.为父元素添加overflow:hidden

如何:清除内外边距

    <style>
        *{
            margin: 0;
            padding: 0;
        }
        /* 清除网页元素的内外边距 */
        /* 这也是css的第一行代码 */

        span{
            background-color: pink;
            margin: 20px;
        }
        
    </style>



<body>
    123
    <ul>
        <li>123456</li>
    </ul>

    <span>行内元素尽量只设置左右内外边距</span>

</body>

网页元素很多都带有默认的内外边距,而且不同浏览器默认的也不一样,所以要先清除网页元素的内外边距。

行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。转换成块级元素和行内块元素就可以了。

二、python学习

第二章

name="E13c"
massage=f"hello {name},would you like"
print(f"{massage}")

first_name="adc"
last_name="qwer"
full_name=f"{first_name} {last_name}"    # f"{} 将括号内的变量赋值,并看做字符串
print(f"{full_name.title()}")            # 首字母大写
print(f"{full_name.upper()}")            # 全部大写
print(f"{full_name.lower()}")            # 全部小写

word='Albert Einstein once said,"A person new."'
print(f"{word}")

famous_name="Albert Einstein"                  # 单引号和双引号都可以扩住字符串,单引号扩住字符串时,内部的双引号正常显示。反过来同理
message=f'{famous_name.title()} once said,"A person new."'
print(message)

first_name="\tadc"            # .strip 剔除函数。消除字符串前后空白
last_name="qwer\t"            # \t空格 \n换行
full_name=f"{first_name} {last_name}"
print(f"{full_name.rstrip()}")
print(f"{full_name.lstrip()}")
print(f"{full_name.strip()}")


universe_age=14_000_000_000_000  # 数字下划线不会显示,只是区分位数
print(universe_age)

x,y,z=0,0,0                  # 同时给多个数赋值
print(x,y,z)

MAX_CONNECTIONS=5000        # 常量一般用大写字母表示

 

第三章

bicycles=['trek','cannondale','redline''specialized']
print(bicycles)

# 访问列表元素
print(bicycles[0].title())

print(bicycles[-1])  # 返回最后一个元素

message=f"My first bicycle was a {bicycles[0].title()}"
print(message)



# 修改、添加和删除元素
# 1.修改
motorcycles=['honda','yamaha','suzuki']
print(motorcycles)
motorcycles[0]='ducati'      # 修改列表元素的值
print(motorcycles)

# 2.添加
motorcycles.append('honda')   # 添加元素到列表末尾
print(motorcycles)


motorcycles=[]               # 通过添加列表元素的方式创建列表
motorcycles.append('honda')
motorcycles.append('honda')
motorcycles.append('honda')
print(motorcycles)


motorcycles=['honda','yamaha','suzuki']
motorcycles.insert(0,'ducati')  # 在对应位置插入元素
print(motorcycles)

# 3.删除
motorcycles=['honda','yamaha','suzuki']
print(motorcycles)

del motorcycles[0]   # 使用del语句删除对应位置元素
print(motorcycles)


motorcycles=['honda','yamaha','suzuki']
print(motorcycles)

popped_motorcycles=motorcycles.pop()    # pop()将最后一个元素弹出,也就是删除最后一个元素
print(motorcycles)
print(popped_motorcycles)


# 弹出列表中任何位置的元素
motorcycles=['honda','yamaha','suzuki']

first_owned=motorcycles.pop(0)
print(first_owned)
print(motorcycles)


# 根据值删除元素(不知道元素的位置)remove只能删除第一个指定的值,要删除的值可能在列表中多次出现,这就需要使用循环
motorcycles=['honda','yamaha','suzuki']
print(motorcycles)

motorcycles.remove('honda')
print(motorcycles)




# 组织列表
# 1.sort()对列表永久排序
cars=['bmw','audi','toyota','subaru']
cars.sort(reverse=True)           # 与字母顺序相反的顺序排列
print(cars)


# 2.sorted()对列表临时排序
cars=['bmw','audi','toyota','subaru']
print("Here is the original list:")
print(cars)

print("\nHere is the sorted list:")
print(sorted(cars))

print("\nHere is the original list again:")
print(cars)


# 3.反转列表元素的排列顺序
cars=['bmw','audi','toyota','subaru']
print("\n")
print(cars)

cars.reverse()
print(cars)


# 4.确定列表长度
print(len(cars))


# 5.使用列表索引时发生索引错误,可以尝试将列表或其长度打印出来。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值