framework7键盘+滑动不兼容

时间:2017-08-25 16:42:59

标签: javascript html-framework-7 keypad

作为标题,当一个键盘在一个滑动范围内时,它将无法工作,任何一个workaroud的想法?

<div class="swiper-container">
    <div class="swiper-wrapper">
        <div class="swiper-slide" style="text-align:center">
            <h3>Product name</h3>
            <div class="range-slider"><input type="range" min="0" value="" step="1" onchange="$$(this).parent().parent().find('span').html(this.value);" oninput="$$(this).parent().parent().find('input').val(this.value);"></div>
            <div class="list-block">
                <ul>
                    <li><div class="item-content">
                        <div class="item-inner">
                            <div class="item-title label">Qtd</div>
                            <div class="item-input">
                                <input type="text" class="kpNumpad">
                            </div>
                        </div>
                    </div></li>
                </ul>
            </div>
            <img  src="img/temp/img01-mobile-md.jpg" style="max-height: 45vh;">
        </div>
    </div>
    <div class="swiper-button-prev"></div>
    <div class="swiper-button-next"></div>
</div>

创建键盘+滑动的脚本:

myApp.keypad({ 'input': '.kpNumpad', 'dotButton': true, 'toolbarCloseText': 'Fechar', 'toolbarTemplate': '' });

myApp.swiper('.swiper-container',{
    'onlyExternal': true,
    'nextButton': '.swiper-button-next',
    'prevButton': '.swiper-button-prev',
    'speed':  600,
    'loop': true, // <- DON'T USE IT, set it to false (see my answer)
    'effect': 'slide' //-- slide, coverflow, flip
});

无论顺序是否首先调用滑键或键盘,它们都不起作用,在浏览器内部进行调试,键盘的div被创建但不显示,输入变得无法解决。

1 个答案:

答案 0 :(得分:0)

通过为每个键盘输入创建实例解决了问题。

window.top.myKeyPad = [];
$$('.kpNumpad').each(function(){
     var kpNum = myApp.keypad({ 'input': $(this), 'dotButton': true,  'toolbarTemplate': '' });
     window.top.myKeyPad.push(kpNum);
});

注意:避免使用Swiper参数&#39; loop&#39; == false,它会打破键盘,同时,我强烈建议不要使用它,因为它会在循环重启时擦除你的输入值