>웹 프론트엔드 >HTML 튜토리얼 >HTML5+CSS3 정적 페이지 프로젝트 경험 요약

HTML5+CSS3 정적 페이지 프로젝트 경험 요약

巴扎黑
巴扎黑원래의
2017-06-27 09:07:074367검색

한동안 프론트엔드를 공부해 왔지만 이론적인 지식은 책에서 읽었지만 실용적인 프로젝트는 거의 없습니다. 형님은 자신이 얼마나 힘을 갖고 있는지, 얼마나 많은 지식을 습득했는지 알고 싶다면 실천하는 것이 가장 좋은 방법이라고 자주 말씀하십니다. 그래서 저는 이번 방학 동안 주로 프로젝트 실습과 이론적 지식의 도움을 통해 코딩 수준을 향상시키기로 결정했습니다. 첫 번째 단계는 몇 가지 HTML5+CSS3 정적 페이지 레이아웃 연습을 수행하고, 누락된 지식 포인트를 확인하고, 연습 중에 발생한 일부 오류를 요약하는 것입니다. 페이지의 디자인 초안은 주로 인터넷에서 찾아보았고, 사진을 자르고, 위치를 측정하고, 내용의 속성을 파악하는 등 실제로 프로젝트를 완성하는 척 하기도 했습니다.

첫 번째 페이지는 플랫폼 디자인 마스터에서 찾았습니다. 이 플랫폼의 페이지 디자인은 주로 외국 디자인을 권장하고 일부 웹 디자인 튜토리얼은 비교적 간단하고 넉넉합니다. 폭발적인 내용의 중국식 페이지에 비해 외국 디자인도 높이 평가합니다.

 디자인 도면의 렌더링은 다음과 같습니다.

 디자인 초안의 페이지 너비는 1550픽셀이고, 페이지 본문은 12열 그리드 레이아웃입니다. 960픽셀. 디자인의 전체 너비가 브라우저의 뷰포트 너비를 훨씬 초과하므로 디자인할 때 정적 페이지이고 반응형 디자인을 사용하지 않았기 때문에 모든 너비와 높이를 정적 크기로 설정했습니다. div 요소를 사용하여 너비를 960px로 설정하고 여백 속성을 0px 자동으로 설정하면 페이지의 기본 콘텐츠가 브라우저 창 중앙에 위치하므로 더 이상 전체 너비에 대해 걱정할 필요가 없습니다. 페이지.

복원된 사진은
디자인 psd를 봤을 때 제 생각은 대충 이랬습니다. 먼저 네비게이션이 두 개, 입력바 하나, 로고 이미지 하나가 있는 네비게이션이 있었습니다. . 열 헤더 뒤에는 웹사이트 배너가 있고, 큰 배너에는 큰 제목, 단락 및 두 개의 버튼 모양 링크가 포함되어 있으며, 그 뒤에는 동일한 레이아웃을 가진 세 개의 모듈이 포함되어 있습니다. 그림, 제목, 단락 및 링크가 있으며 하단에는 탐색 링크 행도 있습니다. 마지막으로 탐색 링크 행과 두 개의 텍스트 단락이 포함된 바닥글이 있습니다.

이 아이디어를 바탕으로 헤더, 섹션, 메인, 바닥글의 네 부분으로 나누어지는 페이지의 프레임워크도 구축하기 시작했습니다. 그리고 각 파트의 내용에 따라 필수 태그를 작성하고, 필요에 따라 class 속성을 추가합니다. 다음 단계는 각 부분별로 페이지 콘텐츠를 조금씩 완성하고 CSS3를 사용하여 스타일을 추가하는 것입니다. 아래의 자세한 설명을 참조하세요.


1. 헤더 부분

위는 헤더의 완성된 그림입니다. 먼저 두 개의 탐색이 두 부분으로 나누어집니다. 첫 번째 줄은 탐색 태그를 사용하여 링크를 삽입합니다. 입력 상자는 둥근 상자로 만들기 위해 테두리 반경을 사용하여 처리되지만 불행히도 들쭉날쭉하고 특히 매끄럽지 않습니다. 링크 양쪽의 수직선은 색상 테두리로 설정됩니다. 다음 행의 탐색은 순서가 지정되지 않은 목록을 사용하고 float 속성을 왼쪽으로 설정하여 왼쪽으로 부동하게 만드는 것입니다. 로고 이미지는 디자인 도면을 컷팅한 결과물입니다. 단점은 2차 링크 표시로 링크한 후 영화에 작은 삼각형이 있다는 점입니다. 제가 게을러서 (유죄) 추가하지 않았습니다. 상세 HTML 코드는 다음과 같습니다.
<header>                 <nav class="firstnav"><div class="headerlimit"> <a href="#" class="firstnav1">Business</a><a href="#" class="firstnav2">Personal</a><input type="text" name="email" placeholder="  Leave your email" class="inputcase1" /><input type="text" name="omit" palaceholder="……" class="inputcase2" /></div><nav class="secondnav"> <div class="headerlimit"> <img src="images/Logo.png" /><div class="headnav"><ul><li><a href="#">Buy</a></li><li><a href="#">Sell</a></li><li><a href="#">Manage</a></li></ul></div></div></nav>    </header>
  其中遇到了一个问题是,图片和无序列表在浏览器中显示时分为了两行,查找了资料以后是使用div元素包含无序列表,并且设值margin和padding的值才使得两个元素在同一行中。无序列表表示链接的CSS代码如下:
.headnav {width: 280px;padding-left: 170px;margin-top: -70px;
}.headerlimit ul {list-style-type: none;padding-left: 0px;
}.headerlimit li a{text-decoration: none;border-left: 1px solid #fff;border-right: 1px solid #ebebeb;width: 90px;text-align: center;line-height: 25px;color: #68676a;float: left;font-family: PTSans;font-size: 14px;
}

二、Banner部分

  背景的大图是使用background-img实现的,而在这个banner部分的设置中使用了position的定位方法,将所有的文字内容模块相对于背景模块的绝对定位,使得在缩小视口的时候,两个模块可以保持位置的不变形、不一位,position属性值也是CSS中很重要的一点。HTML代码和两个模块的绝对定位CSS代码如下:
<section class="banner"><div class="backimg"><div class="bannercontent"> <div class="bannerintr"> <h1>Paul makes your payments easy</h1> <p>With over 1 Billion users, paypal is simply the best way to pay</p> </div> <div class="button1"> <a href="#">  <p>Check this awesome button right here</p> </a> </div> <div class="button2"> <p>Sign up for a paypaul account today</p> <button><a href="#">Click here to join</a></button></div></div></div></section>
.bannercontent {width: 960px;margin: 0px auto;position: absolute;left: 10px;top: 25px;
}.backimg {width: 1055px;height: 415px;margin-left: 195px;background-image: url(../images/banner.png);position: relative;
}
三、Main部分

  因为三个模块的布局是一模一样的,所以只要使用同一个class属性就能保证样式相同。图片和文字都处理都比较简单,没有特别需要指出的了,因此代码也省略了。

四、Footer部分

  在footer部分,导航栏的部分同样是使用无序列表的方式,要注意的是,在设置的时候发现,因为无序列表中设置了向左浮动,因此会影响后面的两个段落在浏览器中的显示,需要使用clear: both; 清除两个段落的浮动,才能使得两个段落在导航栏的下方。问题产生和清除浮动的部分CSS代码如下:

.footernav li a{color: #fff;font-size: 12px;margin-right: 15px;margin-top: 35px;float: left;
}.footercontent {width: 960px;margin: 0px auto;padding: 25px 0px;clear: both;
}

   


  물론 디자인 초안에 따라 이 정적 페이지를 구현할 때 각 요소의 크기, 요소 사이의 간격, 글꼴의 크기 및 색상 속성, 등. 정말 귀찮은 작업(불만). 물론, 당신이 직면하는 실제 문제는 이것이 아니라, 결과적으로 브라우저에 표시될 때 다르게 보일 것이라고 생각하는 것입니다. 따라서 구현 과정에서 발생하는 몇 가지 문제를 기록하고 그 이유와 해결 방법을 찾으려고 노력했습니다.

1. 텍스트와 이미지가 같은 줄이나 같은 div 요소에 나타나면 브라우저는 다른 줄에서 실행됩니다.

정보를 쿼리한 후 세 가지 솔루션이 제공되었습니다.

①CSS에서 div에 대해 Vertical-align: middle; 속성을 설정합니다. 이 div에는 그림과 텍스트가 포함되어 있어 div의 요소를 중앙에 수직으로 정렬할 수 있습니다.

② 이미지가 배경 이미지인 경우, background-img를 이용하여 이미지를 설정하고, 같은 줄에 오도록 텍스트 패딩을 수정합니다.

③이미지와 텍스트를 두 개의 div에 배치하고 여백 값을 설정합니다. 이것이 제가 사용하는 방법인데, 첫 번째 방법보다 조금 더 번거롭습니다.

2. 인라인 요소는 위쪽 및 아래쪽 방향의 여백 및 패딩 속성 값을 지원하지 않습니다. 이를 수정하려면 line-height를 사용해야 합니다.

3. 요소에는 설명할 수 없는 추가 여백이 있는 경우가 많습니다. 이는 실제로 브라우저의 기본 효과이므로 CSS 스타일을 설정하기 전에 이러한 효과를 수동으로 지워야 합니다. 예를 들어, 순서가 지정되지 않은 목록 ul에는 추가 왼쪽 여백이 있습니다.



요약
저도 오래전에 중국 마이크로소프트의 프로젝트를 모방해서 완성했는데, 그 당시에는 전체적인 구조와 레이아웃을 파악하지 못했습니다. , 그리고 그것을 완료하려면 많은 에너지가 필요할 것입니다. 하지만 지난 이틀 동안 이렇게 하는 것은 그다지 힘들지 않을 것입니다. 오랫동안 코딩을 연습하지 않았기 때문에 매우 녹슬지 않을 것이라고 생각했지만 실제로는 여전히 내가 알고 있는 지식 포인트를 알고 있으며 여전히 그렇습니다. 내가 모르는 지식 포인트가 부족하면 정보를 검색하고 사례에 적용할 수 있는 방법을 찾는 것이 실제로 지식 포인트에 대한 이해와 기억력을 향상시킬 수 있습니다. 아직 수준은 높지 않지만, 계속해서 발전하고 있으니 정말 기쁘고 좋을 것 같아요.
매우 능숙해질 때까지 정적 페이지 구현을 계속 연습한 다음 JavaScript에서 동적 페이지 연습을 시작할 것입니다. 이것은 항상 미루는 일이었고 감히 시도하지 않는 것은 금기입니다! 계속해서 좋은 일을 하시고 모두를 따라잡으세요!
디자인 도면 psd, HTML 코드, CSS 코드를 포함한 전체 프로젝트가 github에 게시되어 있습니다. 의욕 있고 능력 있는 분이 저의 부족한 점을 지적해 주셨으면 좋겠습니다. 함께 진행!

위 내용은 HTML5+CSS3 정적 페이지 프로젝트 경험 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.