Maison >interface Web >js tutoriel >Implémentation de l'effet mobile CellSwiper

Implémentation de l'effet mobile CellSwiper

一个新手
一个新手original
2017-10-14 10:36:111503parcourir

Écrit devant

Suite à l'explication précédente de l'effet mobile, il m'est arrivé d'avoir besoin d'utiliser cet effet dans le projet, je suis allé dans la bibliothèque de composants d'Ele.me pour jeter un œil à l'effet. et j'ai constaté que l'effet était le même que celui sur WeChatImplémentation de leffet mobile CellSwiper Il y a encore une légère différence Puisque React est utilisé dans le projet, tous les composants du React utilisé auparavant sont codés lettre par lettre (ce qui est le cas). aussi amer à penser), donc lorsqu'il est combiné avec le précédent swiper, le principe est similaire, obtenant un effet d'extraction similaire à celui de WeChat.

Implémentation de leffet mobile CellSwiper


1. Analyse de base

1.1 Structure HTML

<p class="c-cell-swiper" id="wrapper">
    <p class="cell-content" id="content">
        <p class="your-code">
            <img  class="icon" src="./images/t.jpg" alt="Implémentation de l'effet mobile CellSwiper" ></img>
            <p class="left">
                <span>萌萌的卡洛奇</span>
                <p class="sub">我这个月要来看你啦</p>
            </p>
            <p class="right">now</p>
      </p>
    </p>
    <p class="cell-btn-group" id="btnGroup">
        <p class="cell-btn">标为未读</p>
        <p class="cell-btn">删除</p>
    </p></p>

Nom de la classe dans le code L'endroit marqué de your-code est le code que vous souhaitez ajouter vous-même.

Avant de produire un effet, nous devons d'abord analyser comment nous devons le faire, afin de pouvoir être ciblés. Par exemple, cet effet utilise un retrait de type revêtement, il nécessite donc deux couches. La couche supérieure est responsable du glissement et la couche inférieure est fixe. Lorsque la couche supérieure glisse, la couche inférieure sera naturellement affichée.

Il y a donc deux points :

  • Les couches supérieure et inférieure doivent être positionnées de manière absolue, pour que l'on puisse distinguer les niveaux (au début j'ai essayé que la couche supérieure n'était pas nécessaire de décider du positionnement, et j'ai constaté que lorsque je l'ai déplacé vers le projet, le calque inférieur n'était pas affiché car z-index:-1 était défini au début. Mais pour les pages générales, body a en fait un niveau. , il couvrira donc la couche inférieure, l'empêchant de s'afficher)

  • Puisque le positionnement absolu est utilisé, la hauteur du niveau supérieur doit être calculée

1.2 Analyse du code

Après avoir positionné les calques, vous pouvez essentiellement ignorer le calque de bouton ci-dessous. L'opération principale est toujours en train de glisser. Le balayage peut faire référence au code de balayage précédent, je n'entrerai donc pas dans les détails ici.

1.2.1 Calculer la hauteur et la largeur du groupe de boutons

var el = document.querySelector(&#39;#content&#39;);var btn = document.querySelector(&#39;#btnGroup&#39;);var wrapper = document.querySelector(&#39;#wrapper&#39;);function getBtnGroupWidth() {
    // 按钮组的宽度,滑动的最大距离
    btnGroupWidth = btn.getBoundingClientRect().width;
    wrapperHeight = el.getBoundingClientRect().height;
    // 设置最上层容器的高度
    wrapper.style.height = wrapperHeight + &#39;px&#39;;
    // 设置子容器高度
    el.children[0].style.height = wrapperHeight + &#39;px&#39;;
    // 设置按钮组的line-height,保证按钮组文字居中
    btn.style.lineHeight = wrapperHeight + &#39;px&#39;;}

1.2.2 Coulissant

// 滑动中 ontouchmove// ...// 这里计算的是上层滑动的距离范围// 滑动最远不能超过按钮组宽度// 滑动最小距离就是不滑动,也就是0offsetLeft = Math.min(Math.max(-btnGroupWidth, offsetLeft), 0);translate(el, offsetLeft);// ...// 滑动结束 ontouchend// ...// 如果是tap, 直接关闭if (dragDuration < 300) {
    var fireTap = Math.abs(offsetLeft) < 5 && Math.abs(offsetTop < 5);
    if (isNaN(offsetLeft) || isNaN(offsetTop)) {
        fireTap = true;
    }
    if (fireTap) {
        translate(el, 0, 150);
        opened = false;
        swiping = false;
        return;
    }}var distanceX = Math.abs(offsetLeft);// 如果向左滑动超过了按钮组的40%,辣么在松手的一刻自动滑开// 反之如果向右滑动超过了按钮组的40%就关闭if (distanceX > btnGroupWidth * 0.4 && offsetLeft < 0) {
    translate(el, -btnGroupWidth, 150);
    opened = true;} else {
    translate(el, 0, 150);
    opened = false;}// ...

Résumé

Le tout le processus C'est assez simple de dire que c'est équivalent à swiper On peut dire que c'est en fait une version simplifiée de swiper.

Le point clé est de savoir comment analyser un effet après l'avoir obtenu. Ce n'est qu'avec une idée d'analyse claire qu'une solution raisonnable peut être donnée pour cette analyse. Ici, j'enregistre simplement le processus de création de cet effet et je le partage, j'espère que cela sera utile à tout le monde.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

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