Циклически повторяйте функцию jQuery .post - PullRequest
1 голос
/ 10 марта 2011

Итак, я использую проигрыватель jsplayer HTML5 на своем сайте WordPress, а также некоторый пользовательский скрипт для загрузки в следующем посте и замены старого контента после завершения видео:

    $(document).ready(function(){
        $(".video-js").bind('ended', function(){
            var sStr = "<?php echo get_permalink(get_adjacent_post(true,'',true)); ?>";
            var adj_numb = "<?php 
                            $adj = get_adjacent_post(true,'',true); 
                            $numb = $adj->ID;
                            echo $numb
                            ?>";
            var cur_numb = "<?php echo $post->ID; ?>";
            $.post(sStr, function(data) {
                var content = $( data ).find( '#post-' + adj_numb);
                $( "#post-" + cur_numb ).html( content );
                var vid = VideoJS.setup( "vid" );
                vid.play();
            });
        });
    });

Это прекрасно работает, ровно для одного видео. Он загружает следующее видео и воспроизводит его, но после воспроизведения второго видео он просто останавливается. Я полагаю, это означает, что мне нужно «сбросить» все мои переменные и начать заново с начала скрипта, и что он этого не делает из-за $ (document) .ready (function (), так как он уже все загружен в этот пункт.

Существует ли стандартный способ циклического повторения этого сценария и повторной установки всех переменных после его запуска?

Спасибо!

РЕДАКТИРОВАТЬ: Rendered JS:

    $(document).ready(function(){
        $(".video-js").live('ended', function(){
            var sStr = "http://www.theloniousfilms.com/zachmath/volkswagon/";
            var adj_numb = "94";
            var cur_numb = "96";
            $.post(sStr, function(data) {
                var content = $( data ).find( '#post-' + adj_numb);
                $( "#post-" + cur_numb ).html( content );
                var vid = VideoJS.setup( "vid" );
                vid.play();
            });
        });
    });

HTML:

<div class="post-96 post type-post status-publish format-standard hentry category-zachmath" id="post-96">
            <h2 id="director">Zach Math</h2>

            <h2 id="post_title">Orkin - 
                <span id="post_name">

                "Hot Tub"
                 </span>
                 <span id="home"><a href="http://www.theloniousfilms.com/">HOME</a></span>

                <div class="entry">

                    <div class="video-js-box">
        <!-- Using the Video for Everybody Embed Code http://camendesign.com/code/video_for_everybody --><br />
        <video id="vid" class="video-js" width="640" height="360" preload autoplay poster="http://www.theloniousfilms.com/wp-content/uploads/2011/03/poster.jpg"><br />
          <source src="http://d29zgp48wvs9kv.cloudfront.net/orkin.m4v" type='video/mp4; codecs="avc1.42E01E, mp4a.40.2"' /><br />

          <source src="http://d29zgp48wvs9kv.cloudfront.net/orkin.ogv" type='video/ogg; codecs="theora, vorbis"' /><br />
          <!-- Flash Fallback. Use any flash video player here. Make sure to keep the vjs-flash-fallback class. --><br />
          <object class="vjs-flash-fallback" width="640" height="360" type="application/x-shockwave-flash"<br />
            data="http://releases.flowplayer.org/swf/flowplayer-3.2.1.swf"><param name="movie" value="http://releases.flowplayer.org/swf/flowplayer-3.2.1.swf" /><param name="allowfullscreen" value="true" /><param name="flashvars" value='config={"playlist":["http://www.theloniousfilms.com/wp-content/uploads/2011/03/poster.jpg", {"url": "http://d29zgp48wvs9kv.cloudfront.net/orkin.m4v","autoPlay":true,"autoBuffering":true}]}' /><!-- Image Fallback. Typically the same as the poster image. --><br />
          </object><br />
        </video>
      </div>

Ответы [ 2 ]

0 голосов
/ 26 марта 2011

В итоге я просто извлек все URL-адреса записей в массив, а затем перебрал каждый из них и перешел к следующему элементу в массиве после завершения воспроизведения предыдущего видео.

0 голосов
/ 10 марта 2011

Похоже, HTML переписывается

$( "#post-" + cur_numb ).html( content );

Изменение

$(".video-js").bind('ended', function(){

до

$(".video-js").live('ended', function(){

это должно позаботиться об этом.

Кроме того, измените

$( "#post-" + cur_numb ).html( content );

с

$( "#post-" + cur_numb ).replaceWith( content );
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...