knockoutjs异步调用赋值导致的无缝滚动组件不起作用的处理

​html代码:

<div id="pic_list_3" class="scroll_vertical" data-bind="with:JobVM" >
                            <div class="box" >
                                <ul class="list"  >
                                    <!--ko foreach:$data-->
                                    <li data-bind="text:Name()+'  '+'求职'+'  '+Position()+'  '+Salary()"></li>
                                    <li data-bind="text:Name()+'  '+'求职'+'  '+Position()+'  '+Salary()"></li>
                                    <!--/ko-->

                                </ul>
                            </div>
                        </div>


js代码:

 $(function() {
 $.post("/service/GetIndexJianli", {}, function (data) {
        //console.info(data);
        ko.mapping.fromJS(data, {}, page.VM.JobVM);
         
    });
            $('#pic_list_3').cxScroll({
                direction: 'bottom',
                prevBtn: false,
                nextBtn: false
            });
        });

滚动组件用的是:jquery.cxScroll

由于li的填充用的是knockoutjs with绑定及foreach循环。刚开始怀疑是不是knockoutjs与jquery.cxScroll不兼容。不使用knockoutjs绑定,

而直接用

<li>abc</li>

<li>abc</li>

<li>abc</li>

这样得到的测试数据填充没问题,可以滚动,这似乎应验了不兼容的设想。但我有点不甘心,knockoutjs已经使顺手了。而且我也有点怀疑会不会

是异步加载的问题。因此我着手进行这样得测试。把

$.post("/service/GetIndexJianli", {}, function (data) {
       //console.info(data);
       ko.mapping.fromJS(data, {}, page.VM.JobVM); 
   });

改为:

$.ajax({
       url: "/service/GetIndexJianli",
       async: false,
       success:function(data) {
           ko.mapping.fromJS(data, {}, page.VM.JobVM);
       }
   });

修改后刷新页面查看,能滚动了,看来是异步加载的问题.

另一种处理方法是是在数据加载上后再调用jquery.cxScroll组件,也可以解决此问题:

$.post("/service/GetIndexJianli", {}, function (data) {
        //console.info(data);
        ko.mapping.fromJS(data, {}, page.VM.JobVM);
        $('#pic_list_3').cxScroll({
            direction: 'bottom',
            prevBtn: false,
            nextBtn: false
        });
    });

还有一种解决办法是此代码采用setTimeout()延迟执行

 $('#pic_list_3').cxScroll({
            direction: 'bottom',
            prevBtn: false,
            nextBtn: false
        });

比如选个500ms或者1000ms也可以解决。但是这个不是一个好的选择。因为$.post异步加载的时间是不确定的,依赖网络因素,

如果网络好可以完美解决此问题,如果1秒还没加载上,那就悲剧了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值