新建一个html文件:
data:image/s3,"s3://crabby-images/0319c/0319c2e8d9b2e25f7ed7ac40e9ce6971fcff24f5" alt=""
我要给body添加一些样式,就在head元素上挂载一个style元素。
data:image/s3,"s3://crabby-images/f192f/f192feff5dc43943172fa64bf510cdd9e3a1817b" alt=""
然后,写样式表:
data:image/s3,"s3://crabby-images/5462a/5462af9def7a6a5801ae0d35f538f8c3e31208b6" alt=""
效果:
data:image/s3,"s3://crabby-images/c90c5/c90c5704426611b13ed4e9c121ba8678e8b27615" alt=""
这样的话,我们就可以看到body部分了。现在,我给body添加一点padding。
data:image/s3,"s3://crabby-images/ac97d/ac97d04cd8adbc196a1e3a54b6279c788eab43d9" alt=""
页面上看不出区别,让我们打开F12,看一下现在的body变成了什么样子。
data:image/s3,"s3://crabby-images/7b7fb/7b7fb826026217feaa9d639eadbcf093c2ed3fe9" alt=""
示意图:
data:image/s3,"s3://crabby-images/98d1e/98d1eaf7a715b12a9d850c815428a700a8c200f1" alt=""
从图中可以看出,body元素分为三层,最里面的一层,就是520 x 500的那部分,这个叫做内部真实空间,也就是说,你可以在里面添加其他元素,比如div元素,p元素,a元素等等。然后中间的一层就是padding了,如果你没有加padding,那么这一层就相当于一层薄薄的保鲜膜,其实它没有厚度,就是0px。最外面的一层就是border,在我们这个例子中,body的border部分就只有2px,薄薄的一层。现在,我给body加一个背景色:
data:image/s3,"s3://crabby-images/c8521/c8521dc3dfb79686f6c56f01a99448fb5526c69d" alt=""
data:image/s3,"s3://crabby-images/85273/852736bfed3e9f5e0fb6e2b850519b8b04c0e99d" alt=""
奇怪的是,怎么外面也变成orange了?外面一层是什么啊,是不是html元素啊,那么我们给html元素加一个白色的背景。
data:image/s3,"s3://crabby-images/559bb/559bb0e80bcfc7e0638cd71293fdd76e49d2de05" alt=""
效果:
data:image/s3,"s3://crabby-images/21b67/21b678699be0da130685670271944816ac34e821" alt=""
OK,我们接下来在body元素上挂载一个div元素。
data:image/s3,"s3://crabby-images/eeed7/eeed7c31ffa8494f8096fd6ba42d25b872edecb4" alt=""
注意哦,我现在给这个div元素绑定了一个class属性,属性值叫"wrap",这个class就叫做类,多个元素都可以绑定一个相同的class,通过这个class,我们可以设置一些通用的样式表。以后,但凡是绑定了这个class的元素,都能够拥有相同的样式效果。
现在,我给wrap添加一些样式:
data:image/s3,"s3://crabby-images/0d820/0d82066240dee32b808d6ee22e83a7afda2d6b18" alt=""
注意哦,给class属性设置样式的时候,前面要加一个. ,在上一讲中,我们还说过,给id属性设置样式的时候,前面要加一个#,一样的意思,反正就是这么规定的。
效果:
data:image/s3,"s3://crabby-images/2ffb3/2ffb3d3f823f076703716ce9c25ee97e11b80766" alt=""
我现在把高度改成100%,那么就会自动沾满父容器,也就是这里的body
data:image/s3,"s3://crabby-images/3268b/3268bf82b6ab39607c5e514c4ba9bad28d37e82a" alt=""
效果:
data:image/s3,"s3://crabby-images/343a0/343a0ae95e5f6d93f57698d1ba25d9c8fb221a79" alt=""
那么,蓝色的部分,就是body最里面的那一层,我称之为内部真实空间。中间橘黄色的一层就是padding,最外面那一层薄薄的边界就是border,明白了吗?
好的,接下来开始今天的课程,我们来做一个简单的小页面。
data:image/s3,"s3://crabby-images/0f5e0/0f5e0c13eb0b3b4fee021f6a331bbe094f0f5236" alt=""
我已经把图片都拿过来了。
index.html里面是这样子的:
data:image/s3,"s3://crabby-images/b09e4/b09e4b3b5411a71c32e7ae8e2f2a2e9b3aa756bc" alt=""
接下来,我把必要的元素都放进去。
data:image/s3,"s3://crabby-images/563ef/563ef841f0b1cef8a18365a05cb897dfc9827405" alt=""
OK,我们一个一个来说,首先是h1元素,这个就和word一样的,属于标题元素,h1,就是最大的那种标题。接下来看img元素,这个元素的使用频率是非常高的,现在的网页几乎不可能说没有img元素的,这一点要明确。img元素有一个alt属性,它的意思就是说,当我鼠标画上这张的时候,会有一个小提示。width属性,这个不用多说了吧,设置图片的宽度。src属性,就是这张图片的地址,在我们这个项目中,图片被放在了上级目录的img文件夹下,所以,../ 的意思就是去上级目录,这个属于相对路径,相对于当前文件的路径。在这段代码中,其他元素应该都很好理解了。p元素表示里面的文字是一个段落,h2元素就是二级标题,这些元素都是块级元素。还记得块级元素是什么意思吗?对了,它是不是会默认占满一整行啊。以这个例子来说,他们的父元素就是body,所以,他们会默认占满body的宽度。让我们来看一下效果吧。
把项目跑起来:
data:image/s3,"s3://crabby-images/46065/46065428c6fc79bf59ee564aa0e95e4b04a75585" alt=""
访问:http://localhost/Base/ch03/index.html
data:image/s3,"s3://crabby-images/08706/08706cb496000880fb8b610a74694a29810e9d1c" alt=""
哎呀,图片没有显示,这是怎么回事呢,不要急,我们再来看一下目录结构:
data:image/s3,"s3://crabby-images/e32ba/e32ba58e1ca8b1b7d473829b98ec47d83cd7558f" alt=""
看到了吗,同学们,我们的index.html页面和img文件夹是不是平级的呀?而我们的代码是这样写的:
<img alt="水果蛋糕" width="180px" src="../img/1.jpg"></img>
../ 表示退到上一个目录,也就是这里的ch03文件夹所在的目录:
data:image/s3,"s3://crabby-images/a978a/a978acf2d7d9fbbb217027d9d5628a2c4143917f" alt=""
这样吧,我把文件夹都闭合了。
data:image/s3,"s3://crabby-images/6869a/6869ab3dfd1d7f26bde5235c48a511879b907359" alt=""
ch03文件夹所在的目录是哪里呢,是不是WebContent目录呀?那么,在这个目录下,有没有一个叫做img的文件夹呢,是不是没有呀?所以,我们这里就不需要写../了。直接把../去掉:
data:image/s3,"s3://crabby-images/b510b/b510b91427ada848127e31da7d948872ecc9828c" alt=""
刷新页面:
data:image/s3,"s3://crabby-images/7a520/7a520d101a3fcd363081826a58a67cf461b71b39" alt=""
这样的话,图片是不是就显示出来呀?好的,其实,我们这种src连接的路径,叫做相对路径,在你们学习的过程中,或者从网上,或者从书本上,是不是还听说过一个名词叫做绝对路径啊?那到底什么是绝对路径呢,在本文中,我就给你解释清楚,到底什么是绝对路径?现在,我给img的前面加一个反斜杠:
data:image/s3,"s3://crabby-images/b920f/b920feaa5aff7cc2050951b2dd59850c4b389fd6" alt=""
大伙猜一猜,如果我再次刷新页面,图片能不能显示出来呢?好的,见证奇迹的时刻到了,我刷~
data:image/s3,"s3://crabby-images/eb996/eb99624b5ab07b3217e1bf6f99528a9306e1084f" alt=""
图片是不是又没有了呀?让我们打开F12,发现报错了。
data:image/s3,"s3://crabby-images/31c2e/31c2e40116864399b3722ad1135155260aec5c5a" alt=""
他来了个404错误,404就是找不到资源,也就是说找不到图片。我们看一下,他去哪里找的:http://localhost/img/1.jpg 。看不出来?那我再写一点东西,你自己猜一下,前面这个反斜杠是什么意思。
data:image/s3,"s3://crabby-images/0b6ff/0b6ff73ec7a6c0c391fcc2ffecb58e3150d79887" alt=""
刷新一下:
data:image/s3,"s3://crabby-images/74c27/74c27359eccac840f6ec29b6f52f70f3acdc0be6" alt=""
图片是不是又出来了呀,这个就叫做绝对路径,他和相对路径的区别就是,前面要加一个反斜杠。只要我加了反斜杠,浏览器就会认为我这个是绝对路径。Base是我们的项目发布名称,这个可以去server.xml里面改的。然后:
data:image/s3,"s3://crabby-images/daca1/daca10c38b00cb09e1049340ee4bb99db6e57ab6" alt=""
这一串,对于Web项目来说,他会去你的发布目录的根目录找,也就是WebContent。我们这个项目,是用eclipse生成的,我知道,你们很多人都喜欢用MyEclipse,那么发布目录是不是叫做WebRoot啊。其实啊,这只是一个文件夹的名字而已,我们也完全可以叫其他的名字。现在,我来手动改一下。
data:image/s3,"s3://crabby-images/aec0b/aec0b55b873f88c45908d95d470933b0435da3fb" alt=""
我现在把WebContent的名字改成了target,那么,会怎么样呢?我先卖个关子,接下来,我把tomcat关掉,重新启动一下,请问,同学们,你们觉得我还能不能访问到这个页面?
不好意思,启动报错:
data:image/s3,"s3://crabby-images/2ee5f/2ee5f76b17fb486317f0cc59c51c92ff45556857" alt=""
java.lang.IllegalArgumentException: Document base E:\Java培训\software\eclipse-mars\workspace\Base\WebContent does not exist or is not a readable directory
它说E:\Java培训\software\eclipse-mars\workspace\Base\WebContent这个目录不存在或者不是一个可以读取的目录?我们刚才是不是把WebContent目录的名字改掉了呀,可是tomcat还是认为我们的发布目录名字叫做WebContent,所以就报错了。解决方法,就是手动改一下发布目录,打开server.xml,把那个目录给改掉:
data:image/s3,"s3://crabby-images/0f466/0f46661d04b18d3322d30c23cd64e8908c9a77ba" alt=""
然后,重启tomcat,访问http://localhost/Base/ch03/index.html
data:image/s3,"s3://crabby-images/34842/348427c1c4fbf4d5d53f5e26c0c50509415199de" alt=""
OK了吧,我只是给你们演示一下,各位就不要去改WebContent了,不然的话和服务器上的文件又不一样了。
这个页面有点美中不足的是,有一块溢出了:
data:image/s3,"s3://crabby-images/739fb/739fb062bead176641a5f14ec8432f10d3f6095e" alt=""
可以看到,巧克力蛋糕的说明超出了body的范围,这是因为我们给body设置了一个固定的高度,解决办法就是把高度设置为auto(自适应)
data:image/s3,"s3://crabby-images/40e2a/40e2afaa332d8bc8715d3bf9a462bb9281962c6b" alt=""
data:image/s3,"s3://crabby-images/2d63d/2d63d752c2f0dfd21b38aec0f8bcd0f1e1c4c4fd" alt=""
稍微好看一点了,接下来,我要把body元素中所有的字体改成微软雅黑。
data:image/s3,"s3://crabby-images/7f084/7f084359e6a8149a8d20041a39c7fc2b16010816" alt=""
data:image/s3,"s3://crabby-images/1ffb9/1ffb9009af8f64a71d55d9b81e704415c66320f1" alt=""
然后,给所有的元素来个居中显示:
data:image/s3,"s3://crabby-images/6c708/6c7084e528ab2cbbf5c7961e5c8692392719f706" alt=""
data:image/s3,"s3://crabby-images/5c304/5c304c7870728db5f32ebc7ff42cbec8ed3548f9" alt=""
现在,我又有一个需求,我希望把某些文字设置为不同的颜色,如何做呢?比如,我要把应季水果几个字变成粉红色。同学么,咋办?一个比较好的思路,就是专门用一个元素,把它包进去,比如:
data:image/s3,"s3://crabby-images/a5837/a5837ae428c19b7836e9c9d6c70a92228606c23d" alt=""
在这里,我们是不是只能用行内元素呀,因为如果我们用div,p等块级元素,那么是不是就要换行啦。虽然,我们可以给它设置dispaly:inline-block,或者inline,强制它不换行,可是那样的话,是不是很麻烦呀。所以,为什么不直接使用行内元素呢,比如说font。然后,我们可以给font绑定一个class属性。
data:image/s3,"s3://crabby-images/aff1b/aff1b2757e19f885742a7946fbce9616c9209351" alt=""
然后在style元素中添加一个类选择器
data:image/s3,"s3://crabby-images/95d8d/95d8d4e71e5d7cc3f84dcd34134d7ad567a6ffd8" alt=""
刷新一下页面:
data:image/s3,"s3://crabby-images/b818a/b818aecbf8c93000cf23ba77ec1577180e43aee4" alt=""
好像这个配色不太好看,那么我打开F12,选择这个font元素,重新配一个色(看好了,我就做这么一遍):
data:image/s3,"s3://crabby-images/35554/35554a61c491f05a09e88b7e344b2cf1c7d79a99" alt=""
然后,我们把颜色复制过来:
data:image/s3,"s3://crabby-images/c179f/c179f502593966e8ea46a57dbbff93f39c908495" alt=""
刷新页面:
data:image/s3,"s3://crabby-images/2dd2e/2dd2e0a98cb2622a83730b5b0f6a9eda7f232f93" alt=""
这个就叫做配色,我们也可以给body重新配色:
data:image/s3,"s3://crabby-images/ae214/ae214f247094b36b68bfd5a0d77b566229172235" alt=""
就是这么简单。
网友评论