HTML学习笔记——css基础

简介: 缺点:使用内联样式,样式只能对一个标签生效,如果希望影响到多个元素必须在每一个元素中都复制一遍,并且当样式发生变化时,要多次修改,很麻烦。

前言


今天的学习了尚硅谷老师的css课程,内容为CSS的基础语法等。


网页分成三个部分:结构(HTML)、表现(CSS)、行为(JavaScript)


CSS:


定义:层叠样式表,用来设置网页中元素的样式。


   网页实际上是一个多层的结构,通过css可以分别为网页的每一个层来设置样式,而最终我们能看到的只是网页的最上边一层。


一、使用css修改元素的样式


1、内联样式、行内样式:


       定义:在标签内部通过style属性设置元素的样式。


       缺点:使用内联样式,样式只能对一个标签生效,如果希望影响到多个元素必须在每一个元素中都复制一遍,并且当样式发生变化时,要多次修改,很麻烦。


       注意:练习时可以使用,但开发时绝对不要使用内联样式。


2、内部样式表:


       将样式编写到head中的style标签里面,然后通过css的选择器来选中元素并为其设置各种样式,可以同时为多个标签设置样式,并且修改时只需要修改一处即可全部应用。


      好处: 内部样式表更方便对样式进行复用。


      缺点:只能对一个网页起作用,不能跨页面进行复用。    


3、外部样式表:(最佳)


       可以将css样式编写到一个外部的css文件中,然后通过link标签来引入外部的css文件。


       可以在多个网页引用,使样式在不同页面之间进行复用。


       可以使用浏览器的缓存机制,加快网页的加载速度,提高用户的体验。


       <link rel="stylesheet" href="">

 

二、CSS基本语法


CSS的基本语法为:选择器  声明块


选择器:可以选中页面中的指定元素。


声明块:指定要为元素设置的样式,由一个个声明组成。


声明是一个名值对结构,一个样式名对应一个样式值,名和值 之间以:连接,以;结尾。


三、CSS中的各类选择器


1、 元素选择器:


作用:根据标签名来选中指定的元素。


语法:  标签名{}


2、 id选择器:


作用:根据元素的id属性值选中一个元素,不能重复。


语法:  #id属性值{}


3、类选择器:


作用:class是一个标签的属性,它和id类似,不同的是class可以重复使用,可以通过class属性来为元素分组。


语法: .class属性值


可以同时为一个元素指定多个class属性,多个class之间用空格隔开。


4、通配选择器:


作用:选中页面中的所有元素。


语法:*


5、复合选择器:


作用:选中同时复合多个条件的元素。


语法:选择器1选择器2选择器3选择器n{}


注意:交集选择器中如果又元素选择器,必须使用元素选择器开头。


6、选择器分组(并集选择器):


作用:同时选择多个选择器对应的元素。


语法:选择器1,选择器2,选择器3,选择器n{}


7、关系选择器:


定义:


  • 父元素:直接包含子元素的元素叫做父元素。
  • 子元素:直接被父元素包含的元素是子元素。
  • 祖先元素:直接或间接包含后代元素的元素叫做祖先元素,一个元素的父元素也是它的祖先元素。
  • 后代元素:直接或简介被祖先元素包含的元素,子元素也是后代元素。
  • 兄弟元素:拥有相同父元素的元素。


相关选择器:


1、子元素选择器:选中指定父元素的指定子元素。


        语法:父元素 > 子元素


2、后代元素选择器:选中指定元素内的指定后代元素


        语法: 祖先 后代


3、兄弟元素选择器:选择下一个兄弟


        语法:


        选择紧挨的一个兄弟: 前一个 + 下一个


        选择下边所有的兄弟 :兄 ~ 弟


4、 属性选择器:


        [属性名]   选择含有指定属性的元素


        [属性名=属性值]   选择含有指定属性和属性值的元素


        [属性名^=属性值]   选择属性值以指定值开头的元素


        [属性名$=属性值]   选择属性值以指定值结尾的元素


        [属性名*=属性值]   选择属性值中含某值的元素的元素


8、伪类选择器:


        伪类是不存在的类、特殊的类。 伪类用来描述一个元素的特殊状态,比如:第一个子元素、被点击的元素、鼠标移入的元素...


          伪类一般情况下都是使用:开头


          :first-child  第一个子元素


          :last-child 最后一个子元素


          :nth-child()  选中第n个子元素


                特殊值:n  第n


                   n的范围0到正无穷


                   2n 表示选中偶数位的元素


                   2n+1 或 odd   表示选中奇数位的元素


                   以上这些伪类都是根据所有的子元素进行排序


                   :first-of-type  


                   :last-of-type


                   :nth-of-type()    功能和上述的类似,不同点是他们是在同类型元素中进行排序


                   :not() 否定伪类:将符合条件的元素从选择器中去除。


       超链接的伪类:


       :link 表示没访问过的连接(正常的链接)


       :visited 用来表示访问过的链接,由于隐私的原因,所以visited这个伪类只能修改链接的颜色


       :hover 表示鼠标移入的状态


       :active  表示鼠标点击


       伪元素:表示页面中一些特殊的并不真实存在的元素(特殊的位置),使用 :: 开头


       ::first-letter  表示第一个字母


       ::first-line  表示第一行


       ::selection  表示选中的内容


       ::before 元素的开始


       ::after  元素的最后


       before和after必须结合content属性来使用


总结


以上就是今天的笔记,希望对大家有帮助。

目录
相关文章
|
2天前
|
移动开发 HTML5
HTML5/CSS3粒子效果进度条代码
HTML5/CSS3进度条应用。这款进度条插件在播放进度过程中出现粒子效果,就像一些小颗粒从进度条上散落下来
15 0
HTML5/CSS3粒子效果进度条代码
|
6天前
|
移动开发 前端开发 JavaScript
:掌握移动端开发:HTML5 与 CSS3 的高效实践
:掌握移动端开发:HTML5 与 CSS3 的高效实践
22 1
|
11天前
|
缓存 移动开发 前端开发
【专栏:HTML与CSS前端技术趋势篇】HTML与CSS在PWA(Progressive Web Apps)中的应用
【4月更文挑战第30天】PWA(Progressive Web Apps)结合现代Web技术,提供接近原生应用的体验。HTML在PWA中构建页面结构和内容,响应式设计、语义化标签、Manifest文件和离线页面的创建都离不开HTML。CSS则用于定制主题样式、实现动画效果、响应式布局和管理字体图标。两者协同工作,保证PWA在不同设备和网络环境下的快速、可靠和一致性体验。随着前端技术进步,HTML与CSS在PWA中的应用将更广泛。
|
11天前
|
前端开发 JavaScript 开发者
【专栏:HTML与CSS前端技术趋势篇】前端框架(React/Vue/Angular)与HTML/CSS的结合使用
【4月更文挑战第30天】前端框架React、Vue和Angular助力UI开发,通过组件化、状态管理和虚拟DOM提升效率。这些框架与HTML/CSS结合,使用模板语法、样式管理及组件化思想。未来趋势包括框架简化、Web组件标准采用和CSS在框架中角色的演变。开发者需紧跟技术发展,掌握新工具,提升开发效能。
|
11天前
|
前端开发 JavaScript UED
【专栏:HTML 与 CSS 前端技术趋势篇】Web 性能优化:CSS 与 HTML 的未来趋势
【4月更文挑战第30天】本文探讨了CSS和HTML在Web性能优化中的关键作用,包括样式表压缩、选择器优化、DOM操作减少等策略。随着未来趋势发展,CSS模块系统、自定义属性和响应式设计将得到强化,HTML新特性也将支持复杂组件构建。同时,应对浏览器兼容性、代码复杂度和性能功能平衡的挑战是优化过程中的重要任务。通过案例分析和持续创新,我们可以提升Web应用性能,创造更好的用户体验。
|
11天前
|
移动开发 前端开发 UED
【专栏:HTML与CSS前端技术趋势篇】渐进式增强与优雅降级在前端开发中的实践
【4月更文挑战第30天】前端开发中的渐进式增强和优雅降级是确保跨浏览器、跨设备良好用户体验的关键策略。渐进式增强是从基础功能开始,逐步增加高级特性,保证所有用户能访问基本内容;而优雅降级则是从完整版本出发,向下兼容,确保低版本浏览器仍能使用基本功能。实践中,遵循HTML5/CSS3规范,使用流式布局和响应式设计,检测浏览器特性,并提供备选方案,都是实现这两种策略的有效方法。选择合适策略优化网站,提升用户体验。
|
11天前
|
前端开发 开发者 UED
【专栏:HTML与CSS前端技术趋势篇】网页设计中的CSS Grid与Flexbox之争
【4月更文挑战第30天】本文对比了CSS Grid和Flexbox两种布局工具。Flexbox擅长一维布局,简单易用,适合导航栏和列表;CSS Grid则适用于二维布局,能创建复杂结构,适用于整个页面布局。两者各有优势,在响应式设计中都占有一席之地。随着Web标准发展,它们的结合使用将成为趋势,开发者需掌握两者以应对多样化需求。
|
11天前
|
前端开发 JavaScript 搜索推荐
【专栏:HTML 与 CSS 前端技术趋势篇】HTML 与 CSS 在 Web 组件化中的应用
【4月更文挑战第30天】本文探讨了HTML和CSS在Web组件化中的应用及其在前端趋势中的重要性。组件化提高了代码复用、维护性和扩展性。HTML提供组件结构,语义化标签增进可读性,支持用户交互;CSS实现样式封装、布局控制和主题定制。案例展示了导航栏、卡片和模态框组件的创建。响应式设计、动态样式、CSS预处理器和Web组件标准等趋势影响HTML/CSS在组件化中的应用。面对兼容性、代码复杂度和性能优化挑战,需采取相应策略。未来,持续发掘HTML和CSS潜力,推动组件化开发创新,提升Web应用体验。
|
11天前
|
前端开发 UED
【专栏:HTML与CSS实战项目篇】创建一个具有复杂布局的电商详情页
【4月更文挑战第30天】构建复杂布局的电商详情页涉及页面结构规划、样式设计和交互效果实现。首先规划顶部导航栏、商品图片展示区、商品信息区、用户评价区和相关商品推荐区。在样式设计上,注重色彩搭配、字体选择、布局与间距及图片处理。交互效果包括图片放大、添加到购物车按钮、滚动监听和评论互动,以提升用户体验。实际开发中需考虑跨设备兼容性和用户体验优化。
|
11天前
|
移动开发 前端开发 JavaScript
【专栏:HTML与CSS实战项目篇】使用HTML5与CSS3制作一个动态表单验证页面
【4月更文挑战第30天】本文介绍了使用HTML5和CSS3创建动态表单验证页面的方法。首先,简述HTML5用于构建网页内容,CSS3用于描述样式。接着,分四步展示实现过程:1) 设计包含输入框和提示信息的表单结构;2) 使用CSS3创建样式,增强视觉效果;3) 使用JavaScript监听输入事件,动态验证表单并显示错误信息;4) 测试和调试确保跨平台兼容性。通过学习,开发者能掌握创建带验证功能的表单,提升用户体验。