前端之HTML,CSS(六)
CSS
盒子模型
CSS中的重点,理解盒子模型对于CSS才能有更清晰的认识。网页说简单一点其实就是一块一块的拼接出来的,可以想象成拼图,所有图块拼接在一起就成了一幅图像。如此而言,网页就是拼接后的图像,那盒子就是图块了。
可以看到粗略的把网页的一部分截切成单个小盒子了,小盒子按照这种形式拼接起来就是网页的布局,也就是CSS的主要功能-表现。同样也可使用CSS适当调整一下盒子大小,内容颜色等属性,使得CSS的表现特性更加突出。
大体了解了网页:一个个盒子组成,通过CSS对盒子进行美化和修饰,再完成布局。那么如何修饰美化呢?又如何布局呢?这就是CSS的核心内容了。
盒子模型是由众多种盒子抽象出来的,就如同你学的数学公式一般,它不是天生杵那让你难受的,它是很多人通过无数的计算和实验得出的通性,不是为了为难谁,只是为你提供了更好的解决问题的方法和思路。同样,盒子模型也是为了你的方便,不要觉得抽象难以理解。盒子模型包括四个要素:外边距(margin)、边框(border)、内边距(padding)、内容(content)。
内容(content): 前面CSS的学习,可以发现我们大多都是对文本或者图片设定各种样式的属性,而网页内容大多又是由文本和图片组成,可以理解之前的学习其实就是对盒子中内容表现属性的介绍。上图中,可以看到内容是被黑色边框包裹住的,但是实际网页中内容并不是被包裹的,也不存在黑色边框,只是让我们理解内容是占据一定空间的。
边框(border): 盒子边框,上图中红线部分,网页中较少使用,设置边框一般需要考虑三个属性:边框类型(虚线、实线、或者不存在等)、边框颜色、边框粗细。
border-style: 设置边框类型,缺省默认属性值为none,表示边框不存在。其他属性值:solid(实线)、dashed(线虚线)、dotted(点虚线)。(使用下面测试代码自行测试)
border-color: 设置边框颜色,颜色属性值的设定方式有:red、#f00、rgb(255,0,0)三种类型。
border-width: 设置边框粗细,属性值为像素值(Npx),N为数字。
border: 同font,background相似,设定border属性连写。基本语法:border {border-width属性值 border-style属性值 border-color属性值}。同backgroun一样不需要按照顺序设定,但是border的三个属性必须都存在,页面才会显示border效果。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 盒子模型-测试title >
6 < style type ="text/css" >
7 div {
8 width : 200px ;
9 height : 100px ;
10 border : 2px dashed red ;
11 }
12 style >
13 head >
14 < body >
15 < div > div >
16 body >
17 html >
View Code
等同于:
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 盒子模型-测试title >
6 < style type ="text/css" >
7 div {
8 width : 200px ;
9 height : 100px ;
10 border-style : dotted ;
11 border-width : 2px ;
12 border-color : rgb(255,0,0) ;
13 }
14 style >
15 head >
16 < body >
17 < div > div >
18 body >
19 html >
View Code
边框(border)可以划分为四个边,使用方位名词(left、right、top、bottom)可以单独定义边框的各边进行属性设置。例如:border-left或者border-top-style等
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 盒子模型-测试title >
6 < style type ="text/css" >
7 div {
8 width : 200px ;
9 height : 100px ;
10 border-bottom-style : dotted ;
11 border-bottom-width : 2px ;
12 border-bottom-color : rgb(255,0,0) ;
13 }
14 style >
15 head >
16 < body >
17 < div > div >
18 body >
19 html >
View Code
等同于
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 盒子模型-测试title >
6 < style type ="text/css" >
7 div {
8 width : 200px ;
9 height : 100px ;
10 border-bottom : 2px solid red ;
11 }
12 style >
13 head >
14 < body >
15 < div > div >
16 body >
17 html >
View Code
引申: 标签中输入框边框、
标签表格边框。
1.输入框边框设定
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 输入边框-测试title >
6 < style type ="text/css" >
7 input {
8 border : 0 ; /* 去除边框显示 */
9 border-bottom : 2px solid red ; /* 单独设定边框部分显示 */
10 }
11 style >
12 head >
13 < body >
14 用户名: < input type ="text" name ="uesr_name" >
15 body >
16 html >
View Code
2.表格边框设定
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 表格边框-测试title >
6 < style type ="text/css" >
7 table {
8 width : 200px ;
9 height : 100px ;
10 border : 1px solid gray ;
11 }
12 td {
13 border : 1px solid gray ;
14 }
15 div {
16 width : 200px ;
17 height : 100px ;
18 border : 1px solid gray ;
19 display : inline-block ;
20 }
21 style >
22 head >
23 < body >
24 < table cellspacing ="0" , cellpadding ="0" >
25 < tr >
26 < td > 一号td >
27 < td > 二号td >
28 tr >
29 < tr >
30 < td > 三号td >
31 < td > 四号td >
32 tr >
33 table >
34 < br />
35 < div > div >
36 body >
37 html >
View Code
效果展示:表格边框的粗细与下面div边框属性值设定一样,但是却比div边框要粗一些。原因是:表格是由多个单元格组成,即使cellspacing设置为0,表格中一条线框也是由两个单元格表框组成。
表格细边框问题 :使用border-collapse:collapse;设定相邻边框合并。由此使得表格边框以及单元格边框变细。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 表格边框-测试title >
6 < style type ="text/css" >
7 table {
8 width : 200px ;
9 height : 100px ;
10 border : 1px solid gray ;
11 }
12 td {
13 border : 1px solid gray ;
14 }
15 table,td {
16 border-collapse : collapse ;
17 }
18 div {
19 width : 200px ;
20 height : 100px ;
21 border : 1px solid gray ;
22 display : inline-block ;
23 }
24 style >
25 head >
26 < body >
27 < table cellspacing ="0" , cellpadding ="0" >
28 < tr >
29 < td > 一号td >
30 < td > 二号td >
31 tr >
32 < tr >
33 < td > 三号td >
34 < td > 四号td >
35 tr >
36 table >
37 < br />
38 < div > div >
39 body >
40 html >
View Code
效果展示:
圆角边框(CSS3) :改变盒子边框四角的弧度,属性值可以设定1-4个像素值。例如,border-radius:3px;表示四个角都是3px弧度。border-radius:3px 5px;表示左上角和右下角3px弧度,右上角和左下角5px弧度。border-radius:3px 5px 7px;表示左上角3px,右上角和左下角px,右下角7px弧度。border-radius:3px 5px 7px 9px;表示左上角3px弧度,右上角5px弧度,右下角7px弧度,左下角9px弧度,按顺时针方向,对角线表示。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 圆角问题-测试title >
6 < style type ="text/css" >
7 div {
8 width : 500px ;
9 height : 400px ;
10 border : 1px solid red ;
11 border-radius : 30px 50px 70px 90px ;
12 margin : 150px auto ;
13 }
14 style >
15 head >
16 < body >
17 < div > div >
18 body >
19 html >
View Code
效果展示:
border-radius:50%,作用一个正方形(width=height)可以显示一个圆。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 圆角问题-测试title >
6 < style type ="text/css" >
7 div {
8 width : 300px ;
9 height : 300px ;
10 border : 1px solid red ;
11 border-radius : 50% ;
12 margin : 150px auto ;
13 }
14 style >
15 head >
16 < body >
17 < div > div >
18 body >
19 html >
View Code
内边距(padding): 设置边框与内容之间的距离。可以与方位名词(left、right、top、bottom)结合单独设定内容与某一边框之间的距离。
padding-left: 内容与左边框之间的距离,属性值设定为:Npx,N为数字。
padding-right: 内容与右边框之间的距离,属性值设定为:Npx,N为数字。
padding-top: 内容与上边框之间的距离,属性值设定为:Npx,N为数字。
padding-bottom: 内容与下边框之间的距离,属性值设定为:Npx,N为数字。
padding: 属性值可以设定1-4个像素值。例如,padding:3px;表示上下左右内边距都是3px。padding:3px 5px;表示上下内边距3px,左右内边距5px。padding:3px 5px 7px;表示上内边距3px,左右内边距5px,下内边距7px。padding:3px 5px 7px 9px;表示上内边距3px,右内边距5px,下内边距7px,左内边距9px,按顺时针方向表示。
新浪导航栏案例
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 新浪导航栏案例-测试title >
6 < style type ="text/css" >
7 .nav {
8 height : 50px ;
9 border-top : 3px solid #ff8400 ;
10 border-bottom : 1px solid #edeef0 ;
11 background-color : #fcfcfc ;
12 }
13 .nav a {
14 height : 50px ;
15 text-decoration : none ;
16 display : inline-block ;
17 color : #4c4c4c ;
18 font-size : 14px ;
19 line-height : 50px ;
20 padding-left : 18px ;
21 padding-right : 18px ;
22 }
23 .nav a:hover {
24 color : #ff8400 ;
25 background-color : #edeef0 ;
26 }
27 style >
28 head >
29 < body >
30 < div class ="nav" >
31 < a href ="#" > 首页a >
32 < a href ="#" > 导航栏a >
33 < a href ="#" > 联系我们a >
34 < a href ="#" > 手机客户端a >
35 div >
36 body >
37 html >
View Code
内边距撑大盒子问题: 为盒子添加内边距,盒子大小会发生变化。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 内边距盒子变大问题-测试title >
6 < style type ="text/css" >
7 .nav {
8 width : 100px ;
9 height : 100px ;
10 border : 1px solid red ;
11 }
12 .side {
13 width : 100px ;
14 height : 100px ;
15 border : 1px solid red ;
16 padding : 20px ;
17 }
18 style >
19 head >
20 < body >
21 < div class ="nav" >
22 盒子-1
23 div >
24 < br />
25 < div class ="side" >
26 盒子-2
27 div >
28 body >
29 html >
View Code
效果展示:由上述代码可以看出盒子-1为添加内边距,盒子为100px * 100px,盒子-2是由盒子相同大小添加内边距20px得出的,盒子大小变为140px * 140px ,盒子的大小发生了变化。因此给定盒子大小,考虑内边距大小的,需要修改盒子的width和height属性。width:140px = 100px +20px +20px :左右两个20px边距。其实border也有影响盒子大小。
实际:盒子width = border-left + padding-left + 内容width + padding-right + border-right ,盒子height = border-top + padding-top + 内容height + padding-bottom + border-bottom 。
外边距(margin): 设置盒子与边框或者盒子之间的距离。可以与方位名词(left、right、top、bottom)结合单独设定盒子与某一边框或者其他盒子之间的距离。
margin -left: 盒子与边框或者盒子之间的距离,属性值设定为:Npx,N为数字。
margin -right: 盒子与边框或者盒子之间的距离,属性值设定为:Npx,N为数字。
margin -top: 盒子与边框或者盒子之间的距离,属性值设定为:Npx,N为数字。
margin-bottom: 盒子与边框或者盒子之间的距离,属性值设定为:Npx,N为数字。
margin: 同padding一样,可以设置1-4个属性值,只不过是界定盒子与边框或者盒子之间的距离。margin和padding是两个距离属性。
注意:margin:0 auto;表示盒子水平居中。可以写作margin:auto;auto作用上下无效果,居中需要指定左右auto。重点:margin: 0 auto;使用前提:块级元素,盒子必须指定宽度。
新闻列表案例
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 新闻列表案例-测试title >
6 < style type ="text/css" >
7 body {
8 background-color : #eee ;
9 }
10 * {
11 padding : 0px ;
12 margin : 0px ; /* 清楚所有内外边距 */
13 }
14 .article {
15 width : 380px ;
16 height : 263px ;
17 border : 1px solid #ccc ;
18 padding : 20px 15px 0 ;
19 margin : 150px auto ;
20 }
21 .article h4 {
22 border-bottom : 1px solid #ccc ;
23 color : #202026 ;
24 font-size : 20px ;
25 padding-bottom : 3px ;
26 margin-bottom : 12px ;
27 }
28 li {
29 list-style : none ; /* 清楚列表前符号 */
30 }
31 .article ul li {
32 height : 38px ;
33 border-bottom : 1px dashed #ccc ;
34 line-height : 38px ;
35 text-indent : 2em ;
36 }
37 .article a {
38 text-decoration : none ;
39 font-size : 12px ;
40 color : #333 ;
41 }
42 .article a:hover {
43 text-decoration : underline ;
44 }
45 style >
46 head >
47 < body >
48 < div class ="article" >
49 < h4 > 最新文章/New Articleh4 >
50 < ul >
51 < li >< a href ="#" > 北京招聘网页设计,平面设计,phpa > li >
52 < li >< a href ="#" > 体验javascript的魅力a > li >
53 < li >< a href ="#" > 网页设计师的梦想a > li >
54 < li >< a href ="#" > jquery世界来临a > li >
55 < li >< a href ="#" > jquery中的链式编程是什么a > li >
56 ul >
57 div >
58 body >
59 html >
View Code
相邻块元素垂直外边距合并问题: 上下相邻的两个块元素,上面块元素的设置margin-bottom,下面块元素设置margin-top时,两者之间的垂直间距不是margin-bottom和margin-top之和,而是两者中较大的外边距据值。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题-测试title >
6 < style type ="text/css" >
7 div {
8 width : 300px ;
9 height : 200px ;
10 }
11 .nav {
12 background-color : green ;
13 margin-bottom : 20px ; /* 上面块元素设定下外边距为20px */
14 }
15 .side {
16 background-color : blue ;
17 margin-top : 10px ; /* 下面块元素设定上外边距为10px */
18 }
19 style >
20 head >
21 < body >
22 < div class ="nav" > div >
23 < div class ="side" > div >
24 body >
25 html >
View Code
按照正常理论而言,两个块元素之间的距离应该是30px,而实际为20px。
原因及解决方法:任何浏览器都会存在这个样的问题,可以认为是浏览器bug问题,解决办法是避免这个问题,如果设定两个块元素为30px,可以只设定一方margin即可。如,上面块元素设定:margin-bottom:30px或者下面块元素设定:margin-top:30px。
嵌套块元素垂直外边距合并问题: 两个嵌套关系的块元素,如果父元素没有上内边距及边框,则父元素的上外边距会与子元素的上外边距合并,合并后的外边距为两个外边距的最大值。即使上外边距为0,也会发生合并。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题bug-测试title >
6 < style type ="text/css" >
7 .father {
8 width : 300px ;
9 height : 300px ;
10 background-color : blue ;
11 }
12 .son {
13 width : 100px ;
14 height : 100px ;
15 background-color : green ;
16 margin-top : 20px ; /* 为子元素设定20px上外边距 */
17 }
18 style >
19 head >
20 < body >
21 < div class ="father" >
22 < div class ="son" > div >
23 div >
24 body >
25 html >
View Code
等同于
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题bug-测试title >
6 < style type ="text/css" >
7 .father {
8 width : 300px ;
9 height : 300px ;
10 background-color : blue ;
11 margin-top : 0px ;
12 }
13 .son {
14 width : 100px ;
15 height : 100px ;
16 background-color : green ;
17 margin-top : 20px ; /* 为子元素设定20px上外边距 */
18 }
19 style >
20 head >
21 < body >
22 < div class ="father" >
23 < div class ="son" > div >
24 div >
25 body >
26 html >
View Code
上述代码,按照理论为子元素设定上外边距20px,子元素应该距离父元素上部产生20px距离,然而实际是父元素和子元素均远离浏览器上部20px距离。
调整父元素,设定margin-top:30px
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题bug-测试title >
6 < style type ="text/css" >
7 .father {
8 width : 300px ;
9 height : 300px ;
10 background-color : blue ;
11 margin-top : 30px ;
12 }
13 .son {
14 width : 100px ;
15 height : 100px ;
16 background-color : green ;
17 margin-top : 20px ; /* 为子元素设定20px上外边距 */
18 }
19 style >
20 head >
21 < body >
22 < div class ="father" >
23 < div class ="son" > div >
24 div >
25 body >
26 html >
View Code
可以看到父元素和子元素均远离浏览器上部30px距离。
解决方法:
1.给父元素设定1px的上边框。注意:撑大盒子,需要调整盒子高度。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题-测试title >
6 < style type ="text/css" >
7 .father {
8 width : 300px ;
9 height : 299px ; /* 调整盒子高度 */
10 background-color : blue ;
11 border-top : 1px solid blue ;
12 }
13 .son {
14 width : 100px ;
15 height : 100px ;
16 background-color : green ;
17 margin-top : 20px ; /* 为子元素设定20px上外边距 */
18 }
19 style >
20 head >
21 < body >
22 < div class ="father" >
23 < div class ="son" > div >
24 div >
25 body >
26 html >
View Code
2.给父元素设定20px的上内边距,不为子元素设置20px外边距。注意:撑大盒子,需要调整盒子高度。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题-测试title >
6 < style type ="text/css" >
7 .father {
8 width : 300px ;
9 height : 280px ; /* 调整盒子高度 */
10 background-color : blue ;
11 padding-top : 20px
12 }
13 .son {
14 width : 100px ;
15 height : 100px ;
16 background-color : green ;
17 /* margin-top: 20px; *//* 为子元素设定20px上外边距 */
18 }
19 style >
20 head >
21 < body >
22 < div class ="father" >
23 < div class ="son" > div >
24 div >
25 body >
26 html >
View Code
3.给父元素设置overflow:hidden。
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 外边距问题-测试title >
6 < style type ="text/css" >
7 .father {
8 width : 300px ;
9 height : 300px ; /* 调整盒子高度 */
10 background-color : blue ;
11 overflow : hidden ;
12 }
13 .son {
14 width : 100px ;
15 height : 100px ;
16 background-color : green ;
17 margin-top : 20px ; /* 为子元素设定20px上外边距 */
18 }
19 style >
20 head >
21 < body >
22 < div class ="father" >
23 < div class ="son" > div >
24 div >
25 body >
26 html >
View Code
解决效果:
盒子阴影(CSS3): 基本语法box-shadow:h-shadow v-shadow blur spread color inset;其中前两个属性必须存在,inset表示内部阴影,缺省默认值为outset(外部阴影)。
属性
属性值
描述
h-shadow
像素值
必需,水平阴影位置,可为负值
v-shadow
像素值
必需,垂直阴影位置,可为负值
blur
像素值
模糊程度
spread
像素值
阴影大小
color
颜色
阴影颜色
inset/ourset
inset,outset
inset内部阴影,outset外部阴影
自行改变属性值测试,测试代码:
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 盒子阴影-测试title >
6 < style type ="text/css" >
7 div {
8 width : 300px ;
9 height : 300px ;
10 margin : 150px auto ;
11 box-shadow : 10px 10px 10px 10px red ;
12 /* 缺省默认外部阴影outset */
13 style >
14 head >
15 < body >
16 < div > div >
17 body >
18 html >
View Code
1 DOCTYPE html >
2 < html >
3 < head >
4 < meta charset ="utf-8" >
5 < title > 盒子阴影-测试title >
6 < style type ="text/css" >
7 div {
8 width : 300px ;
9 height : 300px ;
10 margin : 150px auto ;
11 box-shadow : 10px 10px 10px 10px red inset ; /* 内部阴影 */
12 style >
13 head >
14 < body >
15 < div > div >
16 body >
17 html >
View Code
效果展示:
实际盒子阴影写法:box-shadow:npx npx npx npx rgba(0,0,0,0.4);对阴影设定透明度。
转载于:https://www.cnblogs.com/snow-lanuage/p/10453480.html
你可能感兴趣的:(认识CSS中盒子模型)
动态管理用户会话:基于JQuery的会话超时与自动刷新
t0_54program
jquery 前端 javascript 个人开发
在现代Web应用中,会话管理是一个至关重要的功能。如何在用户活跃时动态延长会话时间,以及在用户长时间无操作时自动登出并跳转到登录页面,是提升用户体验和系统安全性的重要环节。本文将通过一个完整的实例,展示如何使用JQuery结合Servlet和JSP实现这一功能。一、问题背景传统的会话超时处理方式通常是在服务器端设置一个固定的超时时间,当用户会话超过这个时间后,服务器会自动销毁会话。然而,这种方式存
Python Cookbook-1.24 让某些字符串大小写不敏感
我不会编程555
#Python学习 python 开发语言
任务让某些字符串在比较和查询的时候是大小写不敏感的,但在其他操作中却保持原状。解决方案最好的解决方式是,将这种字符串封装在str的一个合适的子类中:classiStr(str):"""大小写不敏感的字符串类行为方式类似于str,只是所有的比较和查询都是大小写不敏感的"""def__init__(self,*args):self._lowered=str.lower(self)def__repr__
Spring Data JPA与SpEL:实现通用泛型仓库
t0_54manong
python 数据库 sql 个人开发
在SpringDataJPA中,SpEL(SpringExpressionLanguage)是一种强大的表达式语言,可以用于动态地构建查询语句。通过结合SpEL和泛型,我们可以创建通用的仓库接口,从而减少代码重复并提高开发效率。本文将通过一个具体的例子来展示如何使用SpEL和泛型创建通用仓库。一、背景与需求假设我们有一个任务管理系统,其中包含两种任务类型:异步任务(AsyncTask)和同步任务(
SpringBoot -拦截器Interceptor、过滤器 Filter 及设置
小登ai学习
spring boot 后端
SpringBoot拦截器(Interceptor)的概念-在SpringBoot中,拦截器是一种AOP的实现方式。它主要用于拦截请求,在请求处理之前和之后执行特定的代码逻辑。与过滤器不同的是,拦截器更侧重于对SpringMVC中的控制器(Controller)进行拦截,能够访问到SpringMVC上下文中的对象,比如获取请求的处理器(Handler)信息、模型(Model)和视图(View)相关
transformers.deepspeed
icesord
人工智能 python
报错:nomodulenamedtransformers.deepspeed原因:版本更新后,已取消transformers.deepspeed新版本中更改为transformers.integrations.deepspeed解决方案:根据trace信息,将原先的importtransformers.deepspeedfromtransformers.deepspeedimport......全
蓝桥杯好题推荐-----高精度减法
羽晨同学
C++ 蓝桥杯C++组 蓝桥杯 职场和发展
个人主页:羽晨同学个人格言:“成为自己未来的主人~”题目链接记录详情-洛谷|计算机科学教育新生态https://www.luogu.com.cn/record/205122671思路讲解这个题目的解题思路,其实是和高精度加法是非常像的。怎么说呢,其实开始的时候,由于范围受限的原因,所以我们必须把数字存到字符串中,然后用倒序,存到数组中,然后进行高精度减法,进行高精度减法的时候,我们可以逐个相减,然
flutter 中使用什么本地数据存储
草明
Flutter flutter
在Flutter中,你可以使用多种本地数据存储方式来保存和管理应用程序的数据。以下是一些常用的本地数据存储方式:1.SharedPreferences:shared_preferences包是Flutter的一个插件,用于在应用程序的持久化存储中存储小量的键值对数据。这对于存储用户偏好设置和应用程序配置等数据非常有用。2.SQLite:SQLite是一个轻量级的关系型数据库引擎,可以嵌入到Flut
C++(四)类与对象 下
cloud_disspated
c++ 开发语言
再谈构造函数构造函数体赋值在创建对象时,编译器通过调用构造函数,给对象中各个成员变量一个合适的初始值classDate{public:Date(intyear,intmonth,intday){_year=year;_month=month;_day=day;}private:int_year;int_month;int_day;};虽然上述构造函数调用之后,对象中已经有了一个初始值,但是不能将其
Lua:Lua函数设计与实现_2024-07-14_15-37-17.Tex
chenjj4003
游戏开发2 lua 开发语言 kotlin 网络 android 微信
Lua:Lua函数设计与实现Lua函数基础函数定义与调用在Lua中,函数是一等公民,这意味着它们可以被赋值给变量、存储在数据结构中、作为参数传递给其他函数,甚至可以作为返回值。函数定义使用function关键字,后跟函数名和参数列表,然后是函数体,最后以end结束。--定义一个函数,计算两个数的和functionsum(a,b)returna+bend--调用函数localresult=sum(5
Anaconda 创建环境
aitie1479
python
2019-03-2517:10:51Anaconda给不同的项目创建不同的环境真的非常重要,最近在使用flask的时候在base环境中安装flask-bootstrap,竟然将我原本的py3.7的conda直接删除,完全降到了py2。最后只能重新安装anaconda。这个事件给我一个启示就是尽量不要在初始环境中安装各种包,而是使用anaconda的环境,来给不同的项目分配各自的环境。Anacond
NOIp初赛模拟题及标准答案(提高组)
Mary123123
操作系统 运维 网络
一、单项选择题1、微型计算机中,(C)的存取速度最快。A)高速缓存B)外存储器C)寄存器D)内存储器E)临时存储器2、已知A=35H,则A∧05H∨A∧3OH的结果是:(E)。A)3OHB)05HC)32HD)53HE)35H3、GB2312-80规定了一级汉字3755个,二级汉字3008个,其中二级汉字字库中的汉字是以(B)为序排列的。A.以笔划多少B.以部首C.以ASCⅡ码D.以机内码E.以拼
STM32实战开发(179):智能体育训练计划反馈系统
嵌入式开发项目
stm32 嵌入式硬件 单片机 深度学习 人工智能
引言随着现代科技的不断发展,运动科学领域也在不断取得突破,尤其是在体育训练中,科技的应用越来越普及。从专业运动员到普通健身爱好者,都开始使用智能设备来优化训练计划,提高训练效率。在这个过程中,智能体育训练计划反馈系统作为一种新型的辅助工具,越来越受到关注。智能体育训练计划反馈系统的主要目标是通过实时监测运动员在训练中的生理和运动状态,提供科学的训练反馈,帮助运动员及时调整训练策略,避免过度训练或者
Python Cookbook-2.13 使用C++的类iostream语法
我不会编程555
#Python学习 python 开发语言 windows c++
任务C++的基于ostream和操纵符(插入了这种特定的对象后,它会在stream中产生特定的效果)的I/O方式,并想将此形式用在自己的Python程序中。解决方案Python允许使用对特殊方法(即名字前后带有连续两个下划线的方法)进行了重定义的类来重载原有的操作符。为了将>somewhere,"Theaverageof&dand&dis$f\n"%(1,3,(1+3)/2)这种方式是Python
Django数据迁移
jay丿
django 数据库 sqlite
在Django中,数据迁移是一个核心功能,它允许你通过定义模型(Models)来自动生成数据库表,并且能够随着模型的变化更新数据库结构。下面是对上述命令的详细解释和扩写,以及一些额外的注意事项和技巧。1.检查应用下的模型是否存在异常在执行任何迁移之前,确保你的模型没有语法错误或逻辑问题是很重要的。你可以使用以下命令来检查特定应用下的模型:pythonmanage.pycheckappNameapp
每天一个Flutter开发小项目 (8) : 掌握Flutter网络请求 - 构建每日名言应用
Neo Evolution
Flutter flutter 网络 前端 javascript 数据结构 前端框架
引言欢迎再次回到每天一个Flutter开发小项目系列博客!在之前的七篇博客中,我们已经掌握了FlutterUI构建、状态管理、路由导航、表单处理,甚至数据持久化等一系列核心技能。您已经能够构建功能相对完善的本地应用。然而,在互联网时代,绝大多数应用都需要与服务器进行数据交互,从远程API获取数据,才能展现更丰富的内容和更强大的功能。今天,我们将聚焦Flutter应用的“网络连接”——网络请求,并构
Python笔记
默默前行的蜗牛
python 笔记 开发语言
1.如何在windows同时存在两个版本的Python2,Python3将Python2,Python3的路径添加到path中2.如何使用指定的Python版本pippython3-mpipinstalljupyter3.jupyternotebook使用http://blog.csdn.net/lee_j_r/article/details/52791228jupyternotebook4.中文
LangChain学习笔记
xiaomu_347
LLM——AIGC 学习 笔记
LangChain是一个用来开发大型语言模型(LLM)应用的框架,为了简化构建基于LLM的应用,它能够为开发LLM应用带来如下能力:根据给定的Prompt方便构建上下文,并连接到LLM,得到更加符合查询的回答结果在构建整个基于LLM的应用提供各种工具,如各种模块(Modules)、LCEL、LangGraph等提供工具支持,使用户自己的LLM应用从原型版本到上线到生产环境过程中,一站式的调试、测试
代码随想录刷题学习日记
努力向前ing
代码随想录学习日记 算法 数据结构 学习 回溯
仅为个人记录复盘学习历程,解题思路来自代码随想录代码随想录刷题笔记总结网址:代码随想录40.组合总和II给定一个数组candidates和一个目标数target,找出candidates中所有可以使数字和为target的组合。candidates中的每个数字在每个组合中只能使用一次。说明:所有数字(包括目标数)都是正整数。解集不能包含重复的组合。提供参数:整数数组candicates,目标数tar
代码随想录刷题学习日记
努力向前ing
代码随想录学习日记 算法 哈希算法 学习
仅为个人记录复盘学习历程,解题思路来自代码随想录代码随想录刷题笔记总结网址:代码随想录15.三数之和(双指针法)给定一个包含n个整数的数组nums,判断nums中是否存在三个元素a,b,c,使得a+b+c=0,找出所有满足条件且不重复的三元组。提供参数:整数数组nums主要操作:对数组排序一个for循环遍历nums,控制变量a(nums[i])判断是否整个数组不满足条件对a去重:当前a与上一个a相
微信小程序自定义圆形进度条实现指南
金融先生-Frank
本文还有配套的精品资源,点击获取简介:该指南详细讲解了如何在微信小程序中利用canvas组件创建圆形进度条,涵盖了微信小程序基础、Canvas绘图技术、进度条实现、动态角度计算、动画效果实现、事件监听与交互、样式定制以及项目结构和调试发布等关键知识点。开发者通过本指南可以全面掌握微信小程序中自定义图形的实现方法,并深入理解相关技术细节。1.微信小程序框架和API基础在微信小程序的世界里,一个开发者
C++输入输出(新手教程)
Robots75
c++ 开发语言
目录前言C++的输入输出C++风格输入输出C风格输入输出前言在C++中,输入和输出是非常重要的。在洛谷中,几乎每到题都需要用到输入输出。这篇文章就是简单的给大家介绍了输入输出。C++的输入输出C++风格C++风格的cin和cout需要使用iostream库输入输入一个数的示例代码:#includeusingnamespacestd;intmain(){inta;cin>>a;return0;}解释
C++输入输出语句
sir___sir6
c++ 开发语言
在C++中,常用的输入输出语句主要是通过iostream库提供的cin和cout。这些语句用于从控制台获取输入和向控制台输出内容cin:cin用于从控制台获取输入,通常与提供的变量结合使用。示例:intnum;cin>>num;//从控制台读取一个整数并存储在变量num中输出语句:cout:cout用于向控制台输出内容,可以输出变量的值、文本等。示例:intage=25;coutusingname
基于YOLOv5的野生动物检测与监控系统:猫、狗、鸟、猴子、狮子、老虎、象的实时识别与分析
深度学习&目标检测实战项目
YOLO 目标跟踪 人工智能 深度学习 ui 目标检测 机器学习
1.引言随着人工智能技术的飞速发展,尤其是深度学习在计算机视觉领域的突破,目标检测技术已广泛应用于各类场景。从城市交通监控到安防系统,再到野生动物保护和生态监测,目标检测技术为我们提供了实时、精确的解决方案。在众多目标检测算法中,YOLO(YouOnlyLookOnce)系列因其高效性和实时性,已成为解决多类别目标检测任务的首选方法。本文将介绍如何使用YOLOv5进行野生动物检测与监控,包括猫、狗
(十一)基于vue3+mapbox-GL实现模拟高德实时导航轨迹播放
匹马夕阳
mapbox-gl集锦 前端 人工智能 vue arcgis
要在Vue3项目中结合MapboxGL实现类似高德地图的实时导航轨迹功能,您可以按照以下步骤进行:安装依赖:首先,安装mapbox-gl和@turf/turf这两个必要的库:npminstallmapbox-gl@turf/turf引入MapboxGL:在组件中引入mapbox-gl并初始化地图实例:<script
第17天:深入理解C++友元函数 - 打破封装边界的可控通道
JuicyActiveGilbert
C++相关知识点 c++ 开发语言
第17天:深入理解C++友元函数-打破封装边界的可控通道一、友元函数的本质与价值1.什么是友元函数?友元函数是C++中具有特殊访问权限的外部函数,能够直接访问类的私有(private)和保护(protected)成员。这是对OOP封装原则的有限突破,在保持封装性的同时提供灵活访问。2.为什么需要友元函数?场景常规方案友元方案运算符重载需要公有接口间接访问直接访问私有数据跨类协作增加中间层建立直接访
设计模式之命令模式
Forget the Dream
设计模式 命令模式 java c++
概念命令模式是一种行为型设计模式,它将请求封装成一个对象,从而使你可以用不同的请求对客户进行参数化,对请求排队或者记录请求日志,以及支持可撤销的操作。定义命令模式把一个请求或者操作封装到一个对象中,将发出命令的责任和执行命令的责任分割开。这样,命令的发送者不需要知道命令的接收者是谁,也不需要知道命令是如何被执行的,只需要关心如何发出命令。而命令的接收者只需要专注于如何执行命令,实现具体的业务逻辑。
绘制圆形进度条的编程实现
BitSlinger
编程
绘制圆形进度条的编程实现在本文中,我们将介绍如何使用QT编程框架来绘制一个圆形进度条。圆形进度条是一种常见的用户界面元素,用于显示任务的进度或操作的完成程度。我们将使用QT的绘图功能和自定义小部件来实现这个功能。首先,我们需要创建一个新的QT应用程序,并添加一个自定义小部件来表示圆形进度条。在QT中,我们可以通过继承QWidge类来创建自定义小部件。在这个自定义小部件中,我们将重写paintEve
C++ 数组教程
2501_90255623
c++ 算法 数据结构
一、数组的基本概念在C++中,数组是一种用于存储相同类型元素的固定大小的连续内存块。数组中的每个元素都可以通过索引来访问,索引从0开始。使用数组可以方便地存储和处理一组相关的数据。二、一维数组2.1数组的声明和初始化声明数组声明一维数组的基本语法如下:数据类型数组名[数组大小];例如,声明一个包含5个整数的数组:intnumbers[5];初始化数组部分初始化:可以只初始化数组的一部分元素,未初始
C++ 中 while、continue 和 break 语句教程
2501_90255623
c++
一、while循环语句1.1基本概念和语法while循环是C++中一种基本的循环结构,用于在满足特定条件时重复执行一段代码。其基本语法如下:while(条件表达式){//循环体,包含要重复执行的语句}在每次循环开始前,程序会先计算条件表达式的值。如果表达式的值为true(非零),则执行循环体中的代码;执行完循环体后,会再次检查条件表达式的值,若仍为true,则继续执行循环体,以此类推,直到条件表达
位操作----位运算符详解(按位与(&),按位或(|),按位异或(^),按位取反(~)以及左移(<<)右移(>>))
什么半岛铁盒
c语言 学习方法
前言此文主要为了本人复习知识在学习位操作时,我们首先要清楚的是:1.位运算的符操作数只能是整型和字符型对象2.在计算机中数据都是以二进制存储的(位操作就是直接对二进制进行操作)原码、反码、补码,这是学习位操作必不可少的知识一、原码、反码、补码整数以二进制补码的形式存储在内存中,对于正数的:原码、反码、补码都相同,以下规则针对负整数。原码:根据数值写出的二进制序列反码:以原码为基础,原码符号位不变其
java责任链模式
3213213333332132
java 责任链模式 村民告县长
责任链模式,通常就是一个请求从最低级开始往上层层的请求,当在某一层满足条件时,请求将被处理,当请求到最高层仍未满足时,则请求不会被处理。
就是一个请求在这个链条的责任范围内,会被相应的处理,如果超出链条的责任范围外,请求不会被相应的处理。
下面代码模拟这样的效果:
创建一个政府抽象类,方便所有的具体政府部门继承它。
package 责任链模式;
/**
*
linux、mysql、nginx、tomcat 性能参数优化
ronin47
一、linux 系统内核参数
/etc/sysctl.conf文件常用参数 net.core.netdev_max_backlog = 32768 #允许送到队列的数据包的最大数目
net.core.rmem_max = 8388608 #SOCKET读缓存区大小
net.core.wmem_max = 8388608 #SOCKET写缓存区大
php命令行界面
dcj3sjt126com
PHP cli
常用选项
php -v
php -i PHP安装的有关信息
php -h 访问帮助文件
php -m 列出编译到当前PHP安装的所有模块
执行一段代码
php -r 'echo "hello, world!";'
php -r 'echo "Hello, World!\n";'
php -r '$ts = filemtime("
Filter&Session
171815164
session
Filter
HttpServletRequest requ = (HttpServletRequest) req;
HttpSession session = requ.getSession();
if (session.getAttribute("admin") == null) {
PrintWriter out = res.ge
连接池与Spring,Hibernate结合
g21121
Hibernate
前几篇关于Java连接池的介绍都是基于Java应用的,而我们常用的场景是与Spring和ORM框架结合,下面就利用实例学习一下这方面的配置。
1.下载相关内容: &nb
[简单]mybatis判断数字类型
53873039oycg
mybatis
昨天同事反馈mybatis保存不了int类型的属性,一直报错,错误信息如下:
Caused by: java.lang.NumberFormatException: For input string: "null"
at sun.mis
项目启动时或者启动后ava.lang.OutOfMemoryError: PermGen space
程序员是怎么炼成的
eclipse jvm tomcat catalina.sh eclipse.ini
在启动比较大的项目时,因为存在大量的jsp页面,所以在编译的时候会生成很多的.class文件,.class文件是都会被加载到jvm的方法区中,如果要加载的class文件很多,就会出现方法区溢出异常 java.lang.OutOfMemoryError: PermGen space.
解决办法是点击eclipse里的tomcat,在
我的crm小结
aijuans
crm
各种原因吧,crm今天才完了。主要是接触了几个新技术:
Struts2、poi、ibatis这几个都是以前的项目中用过的。
Jsf、tapestry是这次新接触的,都是界面层的框架,用起来也不难。思路和struts不太一样,传说比较简单方便。不过个人感觉还是struts用着顺手啊,当然springmvc也很顺手,不知道是因为习惯还是什么。jsf和tapestry应用的时候需要知道他们的标签、主
spring里配置使用hibernate的二级缓存几步
antonyup_2006
java spring Hibernate xml cache
.在spring的配置文件中 applicationContent.xml,hibernate部分加入
xml 代码
<prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
<prop key="hi
JAVA基础面试题
百合不是茶
抽象实现接口 String类 接口继承 抽象类继承实体类 自定义异常
/* * 栈(stack):主要保存基本类型(或者叫内置类型)(char、byte、short、 *int、long、 float、double、boolean)和对象的引用,数据可以共享,速度仅次于 * 寄存器(register),快于堆。堆(heap):用于存储对象。 */ &
让sqlmap文件 "继承" 起来
bijian1013
java ibatis sqlmap
多个项目中使用ibatis , 和数据库表对应的 sqlmap文件(增删改查等基本语句),dao, pojo 都是由工具自动生成的, 现在将这些自动生成的文件放在一个单独的工程中,其它项目工程中通过jar包来引用 ,并通过"继承"为基础的sqlmap文件,dao,pojo 添加新的方法来满足项
精通Oracle10编程SQL(13)开发触发器
bijian1013
oracle 数据库 plsql
/*
*开发触发器
*/
--得到日期是周几
select to_char(sysdate+4,'DY','nls_date_language=AMERICAN') from dual;
select to_char(sysdate,'DY','nls_date_language=AMERICAN') from dual;
--建立BEFORE语句触发器
CREATE O
【EhCache三】EhCache查询
bit1129
ehcache
本文介绍EhCache查询缓存中数据,EhCache提供了类似Hibernate的查询API,可以按照给定的条件进行查询。
要对EhCache进行查询,需要在ehcache.xml中设定要查询的属性
数据准备
@Before
public void setUp() {
//加载EhCache配置文件
Inpu
CXF框架入门实例
白糖_
spring Web 框架 webservice servlet
CXF是apache旗下的开源框架,由Celtix + XFire这两门经典的框架合成,是一套非常流行的web service框架。
它提供了JAX-WS的全面支持,并且可以根据实际项目的需要,采用代码优先(Code First)或者 WSDL 优先(WSDL First)来轻松地实现 Web Services 的发布和使用,同时它能与spring进行完美结合。
在apache cxf官网提供
angular.equals
boyitech
AngularJS AngularJS API AnguarJS 中文API angular.equals
angular.equals
描述:
比较两个值或者两个对象是不是 相等。还支持值的类型,正则表达式和数组的比较。 两个值或对象被认为是 相等的前提条件是以下的情况至少能满足一项:
两个值或者对象能通过=== (恒等) 的比较
两个值或者对象是同样类型,并且他们的属性都能通过angular
java-腾讯暑期实习生-输入一个数组A[1,2,...n],求输入B,使得数组B中的第i个数字B[i]=A[0]*A[1]*...*A[i-1]*A[i+1]
bylijinnan
java
这道题的具体思路请参看 何海涛的微博:http://weibo.com/zhedahht
import java.math.BigInteger;
import java.util.Arrays;
public class CreateBFromATencent {
/**
* 题目:输入一个数组A[1,2,...n],求输入B,使得数组B中的第i个数字B[i]=A
FastDFS 的安装和配置 修订版
Chen.H
linux fastDFS 分布式文件系统
FastDFS Home:http://code.google.com/p/fastdfs/
1. 安装
http://code.google.com/p/fastdfs/wiki/Setup http://hi.baidu.com/leolance/blog/item/3c273327978ae55f93580703.html
安装libevent (对libevent的版本要求为1.4.
[强人工智能]拓扑扫描与自适应构造器
comsci
人工智能
当我们面对一个有限拓扑网络的时候,在对已知的拓扑结构进行分析之后,发现在连通点之后,还存在若干个子网络,且这些网络的结构是未知的,数据库中并未存在这些网络的拓扑结构数据....这个时候,我们该怎么办呢?
那么,现在我们必须设计新的模块和代码包来处理上面的问题
oracle merge into的用法
daizj
oracle sql merget into
Oracle中merge into的使用
http://blog.csdn.net/yuzhic/article/details/1896878
http://blog.csdn.net/macle2010/article/details/5980965
该命令使用一条语句从一个或者多个数据源中完成对表的更新和插入数据. ORACLE 9i 中,使用此命令必须同时指定UPDATE 和INSE
不适合使用Hadoop的场景
datamachine
hadoop
转自:http://dev.yesky.com/296/35381296.shtml。
Hadoop通常被认定是能够帮助你解决所有问题的唯一方案。 当人们提到“大数据”或是“数据分析”等相关问题的时候,会听到脱口而出的回答:Hadoop! 实际上Hadoop被设计和建造出来,是用来解决一系列特定问题的。对某些问题来说,Hadoop至多算是一个不好的选择,对另一些问题来说,选择Ha
YII findAll的用法
dcj3sjt126com
yii
看文档比较糊涂,其实挺简单的:
$predictions=Prediction::model()->findAll("uid=:uid",array(":uid"=>10));
第一个参数是选择条件:”uid=10″。其中:uid是一个占位符,在后面的array(“:uid”=>10)对齐进行了赋值;
更完善的查询需要
vim 常用 NERDTree 快捷键
dcj3sjt126com
vim
下面给大家整理了一些vim NERDTree的常用快捷键了,这里几乎包括了所有的快捷键了,希望文章对各位会带来帮助。
切换工作台和目录
ctrl + w + h 光标 focus 左侧树形目录ctrl + w + l 光标 focus 右侧文件显示窗口ctrl + w + w 光标自动在左右侧窗口切换ctrl + w + r 移动当前窗口的布局位置
o 在已有窗口中打开文件、目录或书签,并跳
Java把目录下的文件打印出来
蕃薯耀
列出目录下的文件 文件夹下面的文件 目录下的文件
Java把目录下的文件打印出来
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年7月11日 11:02:
linux远程桌面----VNCServer与rdesktop
hanqunfeng
Desktop
windows远程桌面到linux,需要在linux上安装vncserver,并开启vnc服务,同时需要在windows下使用vnc-viewer访问Linux。vncserver同时支持linux远程桌面到linux。
linux远程桌面到windows,需要在linux上安装rdesktop,同时开启windows的远程桌面访问。
下面分别介绍,以windo
guava中的join和split功能
jackyrong
java
guava库中,包含了很好的join和split的功能,例子如下:
1) 将LIST转换为使用字符串连接的字符串
List<String> names = Lists.newArrayList("John", "Jane", "Adam", "Tom");
Web开发技术十年发展历程
lampcy
android Web 浏览器 html5
回顾web开发技术这十年发展历程:
Ajax
03年的时候我上六年级,那时候网吧刚在小县城的角落萌生。传奇,大话西游第一代网游一时风靡。我抱着试一试的心态给了网吧老板两块钱想申请个号玩玩,然后接下来的一个小时我一直在,注,册,账,号。
彼时网吧用的512k的带宽,注册的时候,填了一堆信息,提交,页面跳转,嘣,”您填写的信息有误,请重填”。然后跳转回注册页面,以此循环。我现在时常想,如果当时a
架构师之mima-----------------mina的非NIO控制IOBuffer(说得比较好)
nannan408
buffer
1.前言。
如题。
2.代码。
IoService
IoService是一个接口,有两种实现:IoAcceptor和IoConnector;其中IoAcceptor是针对Server端的实现,IoConnector是针对Client端的实现;IoService的职责包括:
1、监听器管理
2、IoHandler
3、IoSession
ORA-00054:resource busy and acquire with NOWAIT specified
Everyday都不同
oracle session Lock
[Oracle]
今天对一个数据量很大的表进行操作时,出现如题所示的异常。此时表明数据库的事务处于“忙”的状态,而且被lock了,所以必须先关闭占用的session。
step1,查看被lock的session:
select t2.username, t2.sid, t2.serial#, t2.logon_time
from v$locked_obj
javascript学习笔记
tntxia
JavaScript
javascript里面有6种基本类型的值:number、string、boolean、object、function和undefined。number:就是数字值,包括整数、小数、NaN、正负无穷。string:字符串类型、单双引号引起来的内容。boolean:true、false object:表示所有的javascript对象,不用多说function:我们熟悉的方法,也就是
Java enum的用法详解
xieke90
enum 枚举
Java中枚举实现的分析:
示例:
public static enum SEVERITY{
INFO,WARN,ERROR
}
enum很像特殊的class,实际上enum声明定义的类型就是一个类。 而这些类都是类库中Enum类的子类 (java.l