2016-09-19 1 views
0

Может кто-нибудь, пожалуйста, руководство, как порт ниже угловыми 1 директивы Угловое 2:Угловое 1 угловому 2 Директива Ripple Effect

(function() { 
    'use strict'; 

    angular.module('whimsicalRipple', []) 
    .config(function() { 
     var styleEl = document.createElement('style'), 
     styleSheet, 
     rippleCSS, 
     rippleLightCSS, 
     rippleKeyframes, 
     rippleWebkitKeyframes; 

     rippleCSS = [ 
     '-webkit-animation: ripple 800ms ease-out;', 
     'animation: ripple 800ms ease-out;', 
     'background-color: rgba(0, 0, 0, 0.16);', 
     'border-radius: 100%;', 
     'height: 10px;', 
     'pointer-events: none;', 
     'position: absolute;', 
     'transform: scale(0);', 
     'width: 10px;' 
     ]; 

     rippleLightCSS = 'background-color: rgba(255, 255, 255, 0.32);'; 

     rippleKeyframes = [ 
     '@keyframes ripple {', 
      'to {', 
      'transform: scale(2);', 
      'opacity: 0;', 
      '}', 
     '}' 
     ]; 

     rippleWebkitKeyframes = [ 
     '@-webkit-keyframes ripple {', 
      'to {', 
      '-webkit-transform: scale(2);', 
      'opacity: 0;', 
      '}', 
     '}' 
     ]; 

     document.head.appendChild(styleEl); 
     styleSheet = styleEl.sheet; 
     styleSheet.insertRule('.ripple-effect {' + rippleCSS.join('') + '}', 0); 
     styleSheet.insertRule('.ripple-light .ripple-effect {' + rippleLightCSS + '}', 0); 

     if (CSSRule.WEBKIT_KEYFRAMES_RULE) { // WebKit 
     styleSheet.insertRule(rippleWebkitKeyframes.join(''), 0); 
     } 
     else if (CSSRule.KEYFRAMES_RULE) { // W3C 
     styleSheet.insertRule(rippleKeyframes.join(''), 0); 
     } 
    }) 
    .directive('ripple', function() { 
     return { 
     restrict: 'C', 
     link: function(scope, element, attrs) { 
      element[0].style.position = 'relative'; 
      element[0].style.overflow = 'hidden'; 
      element[0].style.userSelect = 'none'; 

      element[0].style.msUserSelect = 'none'; 
      element[0].style.mozUserSelect = 'none'; 
      element[0].style.webkitUserSelect = 'none'; 


      function createRipple(evt) { 
      var ripple = angular.element('<span class="ripple-effect animate">'), 
       rect = element[0].getBoundingClientRect(), 
       radius = Math.max(rect.height, rect.width), 
       left = evt.pageX - rect.left - radius/2 - document.body.scrollLeft, 
       top = evt.pageY - rect.top - radius/2 - document.body.scrollTop; 

      ripple[0].style.width = ripple[0].style.height = radius + 'px'; 
      ripple[0].style.left = left + 'px'; 
      ripple[0].style.top = top + 'px'; 
      ripple.on('animationend webkitAnimationEnd', function() { 
       angular.element(this).remove(); 
      }); 

      element.append(ripple); 
      } 

      element.on('click', createRipple); 
     } 
     }; 
    }); 
})(); 

Источник: https://github.com/pioug/angular-whimsical-ripple/blob/master/whimsicalRipple.js

ответ

3

Есть несколько способов сделать это. Один из них использует компонент, потому что он позволяет устанавливать стили в свойстве декоратора компонента styles.

Таким образом, секция конфигурации angular1 полностью перемещается в styles свойство компонента:

@Component({ 
    selector: '.ripple', 
    styles: [` 
     :host { 
     display: inline-block; 
     position: relative; 
     overflow: hidden; 
     -webkit-user-select: none; 
     -moz-user-select: none; 
     -ms-user-select: none; 
     user-select: none; 
     cursor: pointer; 
     } 


     @-webkit-keyframes ripple { 
      to { 
      -webkit-transform: scale(2); 
      opacity: 0; 
      } 
     } 

     @keyframes ripple { 
      to { 
      transform: scale(2); 
      opacity: 0; 
      } 
     } 

     :host /deep/ .ripple-effect { 
     -webkit-animation: ripple 800ms ease-out; 
     animation: ripple 800ms ease-out; 
     background-color: rgba(0, 0, 0, 0.16); 
     border-radius: 100%; 
     height: 10px; 
     pointer-events: none; 
     position: absolute; 
     transform: scale(0); 
     width: 10px; 
     } 

     :host /deep/ .ripple-light .ripple-effect { 
     background-color: rgba(255, 255, 255, 0.32); 
     } 
    `], 
    template: '<ng-content></ng-content>', 
}) 
export class RippleComponent { 
    ... 
} 

Смотри также

Второй этап обработки щелкните e вентиляционное отверстие. Для этого есть HostListener декоратор в угловом2. Там нет эквивалента angular.element поэтому я просто использовать DOM API (document.createElement, element.addEventListener):

export class RippleComponent { 
    @HostListener('click', ['$event', '$event.currentTarget']) 
    click(event, element) { 
    var ripple = document.createElement('span'), 
     rect = element.getBoundingClientRect(), 
     radius = Math.max(rect.height, rect.width), 
     left = event.pageX - rect.left - radius/2 - document.body.scrollLeft, 
     top = event.pageY - rect.top - radius/2 - document.body.scrollTop; 

    ripple.className = 'ripple-effect animate'; 
    ripple.style.width = ripple.style.height = radius + 'px'; 
    ripple.style.left = left + 'px'; 
    ripple.style.top = top + 'px'; 
    ripple.addEventListener('animationend',() => { 
     element.removeChild(ripple); 
    }); 

    element.appendChild(ripple); 
    } 
} 

Plunker Example

Plunker Example with image

+0

Спасибо вам столько @yurzui, это было очень полезно. Еще одна вещь, которую я пробовал применить к тегу img, но это не сработало. Возможно, потому что у него нет внутреннего содержимого, но компонент полагается на ng-content, rite? Что можно сделать для работы с изображениями? –

+0

Я немного поменял свой плункер и добавил пример для изображения. – yurzui

+0

Это потрясающе @yurzui. Огромное спасибо. Я изменил событие с щелчка на mousedown, что, кажется, дает гораздо лучший эффект. –