Maison  >  Article  >  interface Web  >  Flexible.js dans js implémente les compétences de schéma de mise en page flexible Taobao_javascript

Flexible.js dans js implémente les compétences de schéma de mise en page flexible Taobao_javascript

WBOY
WBOYoriginal
2016-05-16 15:23:471398parcourir

Le contenu de cet article est de présenter la pratique de la solution de mise en page flexible lib-flexible de Taobao et de la partager avec tout le monde pour votre référence. Le contenu spécifique est le suivant

.

1. Exigences relatives aux pages

Voici à quoi devrait ressembler la page (ne commentez pas le design, ce n'est pas décidé par les développeurs) :

Voici le diagramme des dimensions (750*1334) :

Ensuite, l'artiste fournira des découpes des matériaux suivants en fonction de mes exigences basées sur le brouillon de conception 750*1334 :

Comprend les images d'arrière-plan des deux boutons de téléchargement, le logo, l'arrière-plan dégradé du trapèze inférieur et l'image d'arrière-plan mobile de la partie du corps. Notez que ces images sont toutes découpées à partir du brouillon de conception 750*1334, les tailles sont donc les tailles originales dans le brouillon de conception, comme android.png :

Considérant le problème de l'affichage rétinien, combinez les idées d'adaptation suivantes :

Je pense que la solution réalisable pour résoudre le problème de l'écran rétinien est :

1) Lorsque devicePixelRatiob6fc710540b4e19f00293d913c30312c=2, l'image utilise 750*1,5=1125, qui est l'image coupée du soi-disant brouillon de conception @3x.

J'ai mis toutes les coupes du brouillon de design 750*1334 que m'a donné l'artiste sous le dossier img/@2x :

Ensuite, je lui ai demandé de m'aider à agrandir le vecteur de brouillon de conception 750 de 1,5 fois, puis je m'ai fourni une découpe @3x selon les mêmes exigences de découpe, et je l'ai placée dans le dossier img/@3x :

Théoriquement, la taille de l'image sous @3x devrait être égale à celle de l'image sous @2x*1,5, mais ma coupe n'est pas si parfaite.

Avec l'introduction des exigences précédentes et la préparation du matériel, l'étape suivante consiste à introduire le fichier core js et à écrire le style CSS.

2. Présentez flexible.js

Cette étape est en fait très simple. Copiez simplement le contenu de flexible.js, créez un nouveau fichier flexible.js localement, ouvrez-le et collez-le. Je mets ce fichier sous js/lib :

Introduisez ensuite ce fichier js dans la page html le plus tôt possible (afin de rendre l'effet d'adaptation plus rapide) :

Remarque : utilisez lib-flexible, n'écrivez généralement pas :

Copier le code Le code est le suivant :
660b6d0a1d7dcb25d620df9f8c25cc9c

flexible.js가 자동으로 처리하도록 하세요.

그런 다음 Chrome 시뮬레이터에서 iphone6을 선택하면 html의 글꼴 크기가 글꼴 크기: 75px:

로 설정되어 있는 것을 볼 수 있습니다.

3. CSS 작성
기본 요구 사항:

1) 글꼴 크기를 제외한 모든 크기는 750 마크업 초안 크기를 기준으로 rem 단위의 값으로 변환됩니다. 변환 방법은 마크업 초안 크기/마크업 초안 기본 글꼴 크기입니다. >

2) 주석 초안의 표준 글꼴 크기 = 주석 초안의 너비 / 10. 예를 들어 주석 초안의 너비는 750이고 주석 초안의 표준 글꼴 크기는 75입니다. 주석 초안은 640이고 주석 초안의 표준 글꼴 크기는 64입니다(따라서 Taobao의 이 계획은 모든 디자인 초안 크기에 사용할 수 있습니다)

3) 글꼴 크기를 설정해야 하는 경우 다음과 같이 html의 data-dpr 속성을 따르면 됩니다.

[data-dpr="2"] p {
  font-size: 16px;
}

[data-dpr="3"] p {
  font-size: 24px;
}

이 사용법을 설명하기 위해 Android 다운로드 버튼 스타일을 예로 들어 보겠습니다. android.png의 크기는 414*80이므로 CSS는 다음과 같이 작성됩니다.

.btn {
  width: 414rem/@font-size-base;
  height: 80rem/@font-size-base;
}
less를 사용하기 때문에 주석 초안의 표준 글꼴 크기를 저장하기 위해 변수를 미리 정의합니다.

@font-size-base: 75;

따라서 위와 같이 px2rem으로의 변환이 매우 쉬워집니다. less가 컴파일되면 올바른 rem 값이 계산됩니다.

.btn {
 width: 5.52rem;
 height: 1.06666667rem;
}
이쯤 되면 lib-flexible의 기본 실습은 끝났습니다. 그런데 또 다른 문제가 있는데, 바로 레티나 스크린의 문제입니다. 지금까지는 사진 속 컷아웃을 어떻게 해야 할지 언급하지 않았습니다. 실제로는 매우 간단합니다. html 요소의 data-dpr 속성을 사용하면 devicePixelRatio>=2일 때 @3x에서 이미지를 활성화하도록 다른 미디어 쿼리를 쉽게 구현할 수 있습니다. 예를 들어 다운로드 버튼은 다음과 같습니다.

.btn-android {
 background-image: url("../img/@2x/android.png?v=@@version");
 [data-dpr="3"] & {
  background-image: url("../img/@3x/android.png?v=@@version");
 }
}
이제 괜찮아요. 처음에는 data-dpr의 역할이 뭔지 몰랐는데 지금 보니까 꽤 유용하네요.

참고:

    1) 빌드는 grunt를 사용하므로 먼저 node와 git을 설치한 후 npm을 통해 grunt와 bower를 설치해야 합니다
  • 2) 향후 전체화면 스크롤 효과가 필요할 수 있다는 점을 고려하여 이 페이지는 처음부터 fullpage.js로 제작하였고, jquery와 fullpage.js 라이브러리는 bower를 통해 도입하였습니다
  • 3) 모듈화에서는 requirejs를 사용합니다
  • 4) grunt default를 실행하여 빌드를 완료한 다음 grunt server를 실행하여 정적 서버 미리보기를 시작합니다.
위 내용은 Taobao의 유연한 레이아웃 솔루션인 lib-flexible을 구현하는 전체 과정입니다. 모두의 학습에 영감을 주길 바랍니다.

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn