iScroll a dynamically filled div ONLY without scrolling main page also

后端 未结 1 725
野的像风
野的像风 2021-01-21 09:36

So this post might get lengthy but I\'m stuck with iScroll. What I\'m doing is populating my list with articles and when one gets clicked, I\'m sliding in a div over the list t

相关标签:
1条回答
  • 2021-01-21 10:26

    I finally got it to work. What I needed to do is add another div inside the wrapper div. I'll share the code so hopefully it helps someone else Here's what the new code looks like:

    <body>
        <!--Added scroller div(without iScroll it works also...just make two divs so the body isn't scrolled but the second div is scrolled-->
        <div id="wrapper">
            <div class="scroller">
                <header>Main News</header>
                <ul id="daily"></ul>
                <ul id="exclusive"></ul>
                <ul id="must"></ul>
                <ul id="main"></ul>
                <ul id="ukr"></ul>
                <ul id="nba"></ul>
                <ul id="euro"></ul>
            </div>
        </div>
        <div id="container">
            <div class="scroller">
                <div id="header">
                    <button onclick="hide();">Back</button>
                </div>
                <div id="content"></div>
            </div>
        </div>
    <script>
            $('body').on('touchmove', function(e){
                e.preventDefault();
            });
    //prevents native scrolling so only iScroll is doing the scrolling
    //after the AJAX call to get the content, declare your iScroll variable
    var myScroll;
                myScroll = new iScroll('wrapper');
                setTimeout (function(){
                    myScroll.refresh();
                }, 2000);
    
        //set time out to give the page a little time to load the content and refresh your iScroll variable so it takes in the entire content of the wrapper div
    
    var myScroll1;
            myScroll1 = new iScroll('container');
    //I defined my second iScroll variable here so I can destroy it in the next part...
    
    //function sayhi(url) stays the same but in success of AJAX looks like this:
    success: function(content){
                        $('#content').append(content);
                        myScroll1.destroy();
                        myScroll1 = null;
                        myScroll1 = new iScroll('container');
                        setTimeout (function(){
                            myScroll1.refresh();
                        }, 2000);
                    }
    //when the div slides on the screen and content gets loaded, destroy your second iScroll
    //variable, set it to null and define it all over again so it takes in the entire content
    

    And that's it. Works perfectly now with two divs which need to use iScroll on the same page. Hope the explanation is clear enough and helps someone!!!

    0 讨论(0)
提交回复
热议问题