整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

HTML+CSS基础训练之实现一个“真实”的网页

HTML+CSS基础训练之实现一个“真实”的网页

、任务介绍:

高保真的完成下图布局:

二、分析布局

首先要分析一下各个模块的布局

我们依旧使用的盒子模型。

首先先分为两个大盒子(红色边框)header 盒子和 content 盒子。

其中content中相对对来说比较简单,就需要添加需要的内容文字就好啦。

header相对于基本作业要复杂一些。

在header中首先要分为两个盒子(绿色边框)第一个盒子head装的是标题,下面的盒子info_box装了三个盒子。包括信息盒子info、评论盒子comment_box评论盒子、分享盒子share_box。

评论盒子comment_box中 分为 join div元素和 comment div元素

分享盒子share_box中 分为sina (微博)qqzone(qq空间)wechat(微信)

大体的布局还是用div元素实现,其中信息盒子与评论盒子打算用p+span元素实现,分享盒子用div+“雪碧图”实现。

标题框和内容框的距离为40px。

三、完成html代码

根据我们上面对各个模块布局的分析,我们接下来就可以写html代码啦~其中在header的info盒子,其中信息盒子与评论盒子打算用p+span元素实现(语义化更好一点),分享盒子用div+“雪碧图”实现。

(这里还是有需要的改进的地方,比如行前面的空格我是使用的 空格键,应该还有更好的方法,请大佬指教嘿嘿~)

代码如下:

<html>

<head>
    <title>加分作业
    </title>

    <link rel="stylesheet" href="css/demo2.css">

</head>

<body>
    <div class="container">
        <div class="header">
            <p class="head">啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦</p>
            <div class="info_box">
                <p class="info">
                    <span>2020年5月21日 08:38:23</span><br>
                    <span class="text">来源:</span>
                    <span class="sourse">蜡笔小新酱</span>
                    <span class="icon_1"> </span>
                </p>
                <div class="comment_box">
                    <p class="join"><span>0</span>人参与</p>
                    <p class="comment"><span>0</span>人评论</p>
                    </p>
                </div>
                <div class="share_box">
                    <div class="sina"></div>
                    <div class="qqzone"></div>
                    <div class="wechat"></div>
                </div>
            </div>
        </div>
        <div class="content">
            <p><span>      我的名字是蜡笔小新,我今年五岁,我很快乐,我的妈妈是美牙,我的爸爸是广治
            </span><br>我的朋友有</span><br/>      阿呆<br/>      风间
                <br/>      正南<br/>      妮妮<br/>      小白<br/></p>

        </div>


    </div>
</body>

</html>

四、CSS美化

为了尽可能高保真,我们要测量一下各个模块之间的距离。

标题框和内容框的距离为40px

在整个标题盒子 header中,标题head和信息盒子info_box之间的距离30px

在信息盒子中,来源盒子info和评论盒子comment_box的距离是228px

评论盒子comment_box和分享盒子share_box之间的像素是30px

其中来源盒子info中的时间和来源之间的像素是10px

在评论盒子中的 参与和评论之间的像素为20px

在分享盒子中每个图片之间的距离为10px

css代码如下:

* {
    margin: 0px;
    padding: 0px;
}

.container {
    width: 670px;
    height: 800px;
    margin: auto;
}

.head {
    font: bold 24px Microsoft Yahei;
    margin-top: 40px;
}

.info {
    font: 12px Microsoft Yahei;
    color: #999;
    margin: 25px 0 5px 0;
    line-height: 20px;
    width: 350px;
}

.header {
    height: 142px;
    width: 655px;
    border-bottom: 1px solid #828181;
    display: flex;
    flex-direction: column;
}

.content p {
    line-height: 40px;
    font: Microsoft Yahei;
    color: #636363;
    margin-top: 40px;
}

.content p span {
    line-height: 15px;
}

.icon_1 {
    background: url("../img/icon_1.png") no-repeat 2px center;
    padding: 19px;
}

.info_box {
    display: flex;
}

.comment_box {
    display: flex;
    color: #999;
    margin: 40px 30px 5px 0;
}

.comment_box p {
    font: Microsoft Yahei;
    font-weight: lighter;
    font-size: 12px;
}

.share_box {
    display: flex;
    font-size: 12px;
    height: 40px;
    margin: 32px 0px 5px 0;
}

.join {
    margin: 0px 20px;
}

.qqzone {
    margin-left: 10px;
}

.wechat {
    margin-left: 10px;
}

.comment_box span {
    font-family: 'Georgia';
    font-size: 16px;
    font-style: normal;
    font-weight: bold;
    color: red;
}

.sina {
    background-position: 0px 0px !important;
}

.qqzone {
    background-position: 0px -32px !important;
}

.wechat {
    background-position: 0 -66px !important;
}

.share_box div {
    width: 40px;
    height: 30px;
    background: url(../img/icon_3.jpg);
}

五、CSS美化分析

1.使用行内元素span标签。作为行内元素span标签使用起来也很方便,作为一个小容器,可以把容器分为多个小容器,方便容器中个别部分应用样式,对于容器中其他部分实现特别的效果。其中在评论盒子中用到。如下图。我们可以看到 0人参与 0人评论 可以用p元素一行完成,但是有一个问题,“0”的字体和颜色和别的字不太一样。我们在实现的过程中可以再多写几个div 然后重新布局但是那样太麻烦了,直接使用行内元素就可以搞定。

html代码如下:

 <p class="join"><span>0</span>人参与</p>
 <p class="comment"><span>0</span>人评论</p>

css美化:

.comment_box {
    display: flex;
    color: #999;
    margin: 40px 30px 5px 0;
}
.comment_box span {
    font-family: 'Georgia';
    font-size: 16px;
    font-style: normal;
    font-weight: bold;
    color: red;
}

2.在分享盒子share_box中设置背景图片的时候使用雪碧图。

先来说一说雪碧图是怎么回事

首先把网页中一些背景图片整合到一张图片文件中(png格式)

再利用CSS的"background-image"引入图片,配合"background- repeat"禁止平铺

最后利用css的"background-position"进行背景精确的定位出背景图片的位置(默认起始位置为background-position:0% 0%;如果background-position属性值之设置一个,那么另一个默认为center。

我们需要加载的图片素材是这样的

而我们最后要的效果是这样的,是三张分开的图片,但是都是上面图片的一部分

此时我们就可以用雪碧图啦~先设置 sina wechat qqzone 这三个盒子的大小并使这三个盒子都以这张雪碧图为背景:

.share_box div {
    width: 40px;
    height: 30px;
    background: url(../img/icon_3.jpg);
}

后在各个div中使用background-position进行定位。就是定位到我们想要的部分。

.sina {
    background-position: 0px 0px !important;
}
.qqzone {
    background-position: 0px -32px !important;
}
.wechat {
    background-position: 0 -66px !important;
}

特别要注意一点 在给div添加定位时,要写!important提升指定样式规则的应用优先权。这样才可以定位到不同图片的坐标。

使用雪碧图的优点:如果图片来源于网页的话,就可以减少http请求的次数,提高页面加载速度。方便修改。

六、优化

根据我们以上的效果,我们可以进行一下优化。比如添加背景图片~或者添加鼠标悬停的效果。

在这里,我(突发奇想)设计了此页面的一个深色模式(其实就是把白底黑字换成暗底白色来)还有一些鼠标悬停的效果。

添加背景图片的css代码如下:

.container {
    width: 670px;
    height: 500px;
    margin: auto;
    background-position: center;
    background-image: url(../img/bgimg.jpg);
    background-repeat: no-repeat;
    background-size: 100%;
}

添加鼠标悬停效果css代码如下:

.sourse:hover {
    color: red;
    cursor: pointer;
    text-decoration: underline;
}
.comment_box p:hover {
    cursor: pointer;
    text-decoration: underline;
    color: red;
}
.share_box div {
    cursor: pointer;
}

七:效果展示

高保真:

优化图:

总结和反思:

1,添加css时,一定要写这句:

* {
    margin: 0px;
    padding: 0px;
}

否则会页面的内容不会贴顶,就是总是和页面顶部有一些距离。

2,通过这次实验我更进一步的体会到了盒子模型的一些特点,对boder margin padding 有了更深一步的理解。可以把盒子模型想成一个装在快递盒子里新手机盒。新手机是我们的内容,手机和手机盒的泡沫就是padding(内边框),手机盒子的纸壳就是border(边框),最后手机盒子和快递盒子之间的距离就是margin(外边距)。

喽啊,各位小伙伴们,

又到了有趣实用的隐藏功能学习时间啦~

今天在分享功能之前,我想问一下大家

是否会在日常生活中频繁使用到「Samsung Pay」呢?

如果你的答案是Yes,那你可就来对地方啦!!

Samsung Pay是一种快捷,简单,安全的三星手机专属应用,

支持着银行卡,交通卡,二维码,智能门卡等多种支付方式,

为用户带来了安全,便携的移动支付体验。

而这次,Samsung Pay更是与中国银联

携手推出了「免输卡号绑卡」服务,

为大家的银行卡绑定操作步骤

提供了更加简单方便的绑卡方式~

那么如何开启使用免输卡号绑卡功能呢?

首先,打开「Samsung Pay」>>「首页」>>

「信用卡/借记卡」>>「导入银行卡」,

并进行相关的实名认证,

大家就可以在里面看到各大银行的身影啦~

之后,选择你想授权的具体银行,

并选择相应的银行卡点击同意激活,

最后的最后,进行一次短信验证,

就可以轻松绑定银行卡到Samsung Pay上啦~

是不是超方便呀~~

怎么样?

有没有对三星不断丰富本地化的生态服务所心动呢?

有了免输卡号绑卡功能之后,

不仅减少了绑定银行卡时输入卡号,

姓名等个人信息的繁琐步骤,

还为大家带来更加便携的Samsung Pay操作体验,

真的是爱了爱了~~




*需使用带有“银联”标识的卡片。

*某些银行/机构的部分卡片类型可能暂不支持,请联系银行/机构,确认卡片是否适用。

*支持此功能的设备需将Samsung Pay升级至4.1.24及以上版本,每一型号是否支持的功能以Samsung Pay APP内提示为准。





文章转载三星盖乐世社区:

https://www.samsungmembers.cn/thread-1343417-4-10.html 作者:泡泡土

#34;夏哉ke":chaoxingit.com/5056/

前端必学:40个精选案例实战,一课吃透HTML5 + CSS3 + JavaScript

引言

前端开发是现代Web应用开发的重要组成部分,掌握HTML5、CSS3和JavaScript是入门前端开发的基础。本文将介绍40个精选的实战案例,帮助你系统学习和应用这些技术。通过这些案例,你将深入理解各种前端技术的应用场景和实际操作,为成为优秀的前端开发人员打下坚实的基础。

HTML5 实战案例

  1. 基本结构和语义化标签:构建一个简单的静态网页,使用<header>、<nav>、<section>、<footer>等HTML5标签。
  2. 表单验证:利用HTML5表单验证属性如required、pattern等,实现一个注册表单。
  3. 视频播放器:使用<video>标签嵌入视频,并添加播放、暂停、全屏等控制功能。
  4. Canvas绘图:通过Canvas API绘制简单的图形,如矩形、圆形等,实现动态效果。
  5. 本地存储:使用localStorage或sessionStorage实现一个简单的记事本功能,保存用户输入的数据。

CSS3 实战案例

  1. 响应式布局:利用CSS3媒体查询和弹性布局(Flexbox)实现一个响应式网页,适应不同设备的屏幕尺寸。
  2. 动画效果:使用CSS3动画和过渡效果,如淡入淡出、旋转、缩放等,增强用户体验。
  3. 阴影和圆角:应用CSS3的box-shadow和border-radius属性,美化按钮或图片的外观。
  4. 多列布局:使用CSS3多列布局(column-count和column-gap)创建类似报纸的多列文本布局。
  5. 自定义字体:通过@font-face引入自定义字体文件(如WOFF或WOFF2),使网页字体更具个性化。

JavaScript 实战案例

  1. DOM操作:使用JavaScript操作DOM元素,动态改变页面内容或样式。
  2. 事件处理:绑定常见的DOM事件(点击、鼠标移入移出等),实现交互效果。
  3. 轮播图:利用JavaScript编写一个简单的轮播图组件,支持自动播放和手动切换。
  4. 数据请求与展示:使用Fetch API或XMLHttpRequest获取远程数据,并在页面中展示。
  5. 表单处理:通过JavaScript验证表单数据,实现更复杂的表单交互,如动态添加表单项或条件判断。

综合实战案例

  1. 网页时钟:利用HTML5的Canvas绘制时钟表盘,JavaScript实现实时更新时钟指针位置。
  2. 天气预报小工具:通过API获取天气数据,使用CSS3设计气泡式样式,JavaScript展示天气信息。
  3. Todo List:实现一个简单的任务清单应用,支持任务增删改查操作,数据使用localStorage保存。
  4. 在线画板:结合Canvas和事件处理,实现一个支持绘图、橡皮擦和颜色选择的在线画板。
  5. 响应式导航栏:使用Flexbox和媒体查询创建一个适应不同屏幕尺寸的导航菜单。

高级实战案例

  1. 网页拖放:利用HTML5的Drag and Drop API实现拖放功能,如图片上传或元素排序。
  2. 地图交互:集成第三方地图API(如Google Maps API),实现地图标记、路线规划等功能。
  3. WebSocket通讯:使用WebSocket API实现实时聊天应用,实现客户端和服务器之间的双向通信。
  4. 音频可视化:利用Web Audio API获取音频数据,通过Canvas实时绘制音频频谱图。
  5. Web动态效果:结合CSS3动画和JavaScript,实现页面滚动时元素的动态加载和特效展示。

进阶实战案例

  1. 响应式图片展示:使用srcset和sizes属性优化图片加载,根据设备像素比和屏幕大小自动选择最优图片。
  2. WebGL 3D场景:利用Three.js等WebGL库创建一个简单的3D场景,如旋转的立方体或球体。
  3. 数据可视化:使用D3.js或Chart.js等库,实现数据的图表展示和动态更新。
  4. 移动端交互:开发一个基于触摸事件的移动端应用,如滑动菜单、手势识别等。
  5. 单页应用(SPA):使用React、Angular或Vue.js等前端框架,开发一个简单的单页应用,实现路由控制和组件化开发。

实用工具和技巧

  1. 代码优化和压缩:使用工具如Webpack或Parcel进行前端代码的优化、压缩和打包。
  2. 跨浏览器兼容性:利用Autoprefixer等工具自动处理CSS前缀,确保在各大浏览器中的兼容性。
  3. 性能优化:使用Chrome DevTools等工具进行性能分析,优化页面加载速度和响应时间。
  4. 前端安全:实施前端安全措施,如跨站脚本(XSS)攻击防护、数据加密等。
  5. 版本控制:使用Git进行代码版本控制,结合GitHub或GitLab进行团队协作和代码托管。

结语

通过上述40个实战案例,你可以全面掌握HTML5、CSS3和JavaScript的核心技术和应用场景。在学习过程中,建议结合实际项目或练习,不断深化理解和提升实践能力。前端开发是一个快速发展的领域,持续学习和探索新技术将帮助你成为一名优秀的前端工程师。