css常见问题处理

文章目录

1:禁止文字被复制粘贴

1.1 Css 处理

html 复制代码
<div class="text">我不可以复制信息</div>
<div>
    我可以复制
</div>
<style>
    .text {
        -webkit-user-select: none;
    }
</style>

1.2 Js 处理

javascript 复制代码
<script>
    <!-- 禁止右键 -->
    document.oncontextmenu = () => false
	<!-- 禁止文字选择 -->	
	document.onselectstart = () => false
</script>

2:元素垂直水平居中

2.1:方案一

使用弹性布局,父元素设置display: flex另外再设置属性:水平布局justify-content: center;和垂直布局 align-items: center;

html 复制代码
<div class="ha"><div class="child"></div></div>
<style>
    .ha {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 200px;
        height: 200px;
        background-color: #000;
    }
    .child {
        width: 80px;
        height: 80px;
        background-color: blue;
    }  
</style>

2.2 方案二

position: absolute; 位移属性

使用position: absolute; 属性各百分之五十,top: 50%;left: 50%;然后margin减去元素的一半(在已知宽高情况下);

html 复制代码
<div class="ha"><div class="child"></div></div>
<style>	
    .ha {
        width: 600px;
        height: 600px;
        background-color: grey;
        position: relative;
    }
    .child {
        position: absolute;
        top: 50%;
        left: 50%;
        margin-top: -100px;
        margin-left: -100px;
        width: 200px;
        height: 200px;
        background-color: #000;
    }
</style>

2.3 方案三

使用calc()函数进行计算,这个方法和上面方案二类似

html 复制代码
<div class="ha"><div class="child"></div></div>
<style>
    .ha {
        width: 600px;
        height: 600px;
        background-color: grey;
        position: relative;
    }
    .child {
        position: absolute;
        top: calc(50% - 100px);
        left: calc(50% - 100px);
        width: 200px;
        height: 200px;
        background-color: blue;
    }
</style>

2.4 方案四

使用 平移属性 transform: translate(x轴,y轴)进行位移,各减去元素宽高的一半

margin 和 calc() 函数是在已知元素宽高的情况下进行的处理,在不知道元素宽高的情况下,可以使用transform平移属性进行处理

css 复制代码
.child {
    position: absolute;
    top: 50%;
    left: 50%;
    // transform: translate(-100px, -100px);  //已知元素宽高
    transform: translate(-50%, -50%);  // 元素比例
    width: 200px;
    height: 200px;
    background-color: blue;
}

2.5 方案五

使用网格布局 父元素声明 display: grid; 子元素使用 align-self: center; justify-self: center;

html 复制代码
<div class="ha"><div class="child"></div></div>
<style>
    .ha {
        width: 600px;
        height: 600px;
        background-color: grey;
        display: grid;
    }
    .child {
       align-self: center;
       // margin: 0 auto;   // 让元素水平居中
       justify-self: center;  // 网格布局的属性
       width: 200px;
       height: 200px;
       background-color: blue;
    }
</style>

只在父元素上添加属性

display: grid; align-items: center; justify-content: center;

css 复制代码
.ha {
    width: 600px;
    height: 600px;
    background-color: grey;
    display: grid;
    align-items: center;
    justify-content: center;
}
.child {
    width: 200px;
    height: 200px;
    background-color: blue;
}
相关推荐
明君879979 分钟前
说说我为什么放弃使用 GetX,转而使用 flutter_bloc + GetIt
前端·flutter
Jingyou11 分钟前
用 Astro 搭建个人博客:从零到上线的完整实践
前端
吴声子夜歌16 分钟前
JavaScript——call()、apply()和bind()
开发语言·前端·javascript
高桥凉介发量惊人21 分钟前
质量与交付篇(2/6):CI/CD 实战——自动构建、签名、分发
前端
leafyyuki23 分钟前
SSE 同域长连接排队问题解析与前端最佳实践
前端·javascript·人工智能
高桥凉介发量惊人23 分钟前
质量与交付篇(3/6):崩溃分析与线上问题回溯机制
前端
angerdream24 分钟前
最新版vue3+TypeScript开发入门到实战教程之路由详解三
前端·javascript·vue.js
毕设源码-郭学长35 分钟前
【开题答辩全过程】以 基于Web的网上问诊系统的设计与实现为例,包含答辩的问题和答案
前端
酉鬼女又兒1 小时前
零基础快速入门前端DOM 操作核心知识与实战解析(完整汇总版)(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯·js
喝拿铁写前端2 小时前
一套面向 Web、H5、小程序与 Flutter 的多端一致性技术方案
前端·架构