2009-08-12 10 views

Odpowiedz

1

Twoja "metoda ajax-y" to jedyny sposób, aby to przyspieszyć. Duże witryny będą korzystać z CDN i mają dobre buforowanie. Nie ma sposobu, aby duże pliki zabierały dużo czasu ...

Utrzymanie obiektu lub tagu wideo poza kodem HTML, a następnie dodanie go po wczytaniu strony, poprawi postrzeganą wydajność ładowania strony. Być może zamienić obraz ekranowy, który ma taki sam rozmiar jak ewentualne wideo ...

Wcześnie za tag wideo, ale możliwe, że w końcu czas inicjalizacji będzie szybszy niż Flash, ponieważ jest częścią przeglądarki a nie wtyczką 3rd party.

Większość czasu ładowania wideo zależy od sposobu zakodowania/przesłania filmu, który jest poza kontrolą użytkownika.

1

Nie ma wątpliwości, że pobieranie wielu filmów z różnych stron internetowych wymaga czasu. Czy próbowałeś uzyskać kopię tych filmów, przesłać je na swój serwer sieciowy i osadzać w ten sposób swoje filmy? Może to zwiększyć szybkość wyświetlania twoich stron, jeśli filmy pochodzą z jednego źródła.

+0

Dzięki za sugestię, chutsu. To dobra uwaga, ale niestety nie sądzę, że będzie możliwe uzyskanie kopii innych niż tylko osadzanie filmów. – VirtuosiMedia

+0

Dlaczego nie? Możesz pobrać filmy flash za pomocą wtyczki firefox "FlashGot" (użyj dobrego starego google, aby uzyskać więcej informacji na temat pobierania filmów "flv"). I umieść wideo flv na swojej stronie. – chutsu

+1

Nie sądzę, aby umieszczenie wszystkich mediów na tym samym serwerze przyspieszyło. Większość dużych witryn umieszcza obrazy i inne statyczne treści w innym hoście, aby zwiększyć szybkość. Głównym powodem jest to, że przeglądarki mają maksymalną liczbę równoczesnych połączeń z jednym hostem. A jeśli serwer YouTube może być szybszy niż twój serwer. –

9

Problem z osadzonymi filmami z YouTube polega na tym, że sam odtwarzacz musi się wczytać. Możesz dodać "controls = 2" w adresie URL kodu do osadzania, ale to spowoduje, że tylko gracze AS2/3 będą ładować odtwarzacz po kliknięciu.

W przypadku tego problemu obejście tego problemu nie polega na załadowaniu odtwarzacza. Zamiast tego ładuje miniaturę z nałożonym przyciskiem odtwarzania. Po kliknięciu obraz zostaje zastąpiony rzeczywistym kodem osadzania iframe w odtwarzaczu YouTube i ładuje się i automatycznie odtwarza.

Można to zrobić na dowolnej stronie, używając prostego kodu javascript poniżej. https://skipser.googlecode.com/files/gplus-youtubeembed.js

+0

Wydaje się, że do tej pory działa to naprawdę dobrze. Dzięki! – tom

+0

Dzięki za pracę nad tym. Próbuję twojej poprawki pod adresem: https://www.acls.net/videos.htm bezskutecznie. –

1

Rozwiązanie Google Plus to jedyny sposób na zwiększenie wydajności: wczytaj kod obrazka, a następnie załaduj pełny odtwarzacz, gdy użytkownik kliknie.

Opierając się na rozwiązanie z @boscharun tutaj jest rozwiązanie używam:

<style> 
div.video-container a img.playbutton {visibility: hidden; 
    content:url("") 
} 
div.video-container a:hover .playbutton {visibility: visible;} 
</style>    

<div class="video-container"> 
    <a style="position: relative; left: 0; top: 0;" href="https://www.youtube.com/watch?v=IJl2C8QPVjQ&amp;rel=0"> 
    <img src="//img.youtube.com/vi/IJl2C8QPVjQ/0.jpg" style="position: relative; top: 0; left: 0; width:100%; height:auto"> 
    <img class="playbutton" style="position: absolute; top: 50%; left: 50%; margin-left:-38px; margin-top:-38px"> 
    </a> 
</div> 

<script> 
$('.video-container').click(
    function(e){ 
    e.preventDefault(); 
    var imgURL = $(this).find("img").attr('src'); 
    var rx = /\/vi\/([^\/]+)/ 
    var arr = rx.exec(imgURL); 
    var url = "//www.youtube.com/embed/"+arr[1]+"?rel=0&autoplay=1"; 
    $(this).find("img").hide(); 
    $(this).append('<iframe width="100%" height="315" src="'+url+'" frameborder="0" allowfullscreen></iframe>'); 
    } 
); 
</script>      

Można go zobaczyć w akcji na żywo pod adresem: https://www.acls.net/videos.htm

Funkcje obejmują:

  • pogarszają się IMG w razie potrzeby
  • Semantic
  • Responsive
  • Używa jQuery
-1

Można postępować zgodnie z instrukcjami z: https://varvy.com/pagespeed/defer-videos.html

tylko zamiast za pomocą kodu:

<iframe width="560" height="315" src="" data-src="//www.youtube.com/embed/OMOVFvcNfvE" frameborder="0" allowfullscreen></iframe> 

chciałbym zmienić przez:

<iframe width="560" height="315" data-src="//www.youtube.com/embed/OMOVFvcNfvE" frameborder="0" allowfullscreen></iframe> 

Ponieważ, src = "" może być interpretowane jako src = "/" w niektórych przeglądarkach, które załadują kopię Twojej witryny do elementu iframe ...

Powiązane problemy