我慢慢地对这个绝望了。我有一个项目,我使用 RequireJS 来分隔我的 JS 代码。我已经设法启动并运行它,但现在我在使用iscrollview库时遇到了困难。这提供了在 jQuery Mobile 网站中使用的iScroll实现。这是一些代码来勾画我的情况:
索引.html:
<!DOCTYPE html>
<html>
<head>
<title>iscrollview</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" href="js/lib/jquery-mobile/jquery.mobile-1.2.0.min.css" />
<link rel="stylesheet" type="text/css" href="js/lib/iscrollview/iscrollview.css" />
<script type="text/javascript" data-main="js/main.js" src="js/lib/require/require-2.1.1.min.js"></script>
</head>
<body>
<div data-role="page">
<div data-role="header">
<h1>Header</h1>
</div>
<div data-role="content">
<div data-iscroll>
<!-- this contains some long content (long enough to trigger scrolling) -->
</div>
</div>
<div data-role="footer">
<h2>Footer</h2>
</div>
</div>
</body>
</html>
js/main.js:
requirejs.config({
baseUrl: 'js',
paths: {
jquery: 'lib/jquery/jquery-1.8.2.min',
jquerymobile: 'lib/jquery-mobile/jquery.mobile-1.2.0.min',
iscroll: 'lib/iscroll/iscroll',
iscrollview: 'lib/iscrollview/iscrollview'
},
shim: {
jquerymobile: {
deps: ['jquery']
},
iscroll: {
deps: ['jquerymobile']
},
iscrollview: {
deps: ['iscroll']
}
}
});
requirejs(['jquery','jquerymobile','iscroll','iscrollview'], function($){
/* I would expect that the correct JS files are loaded by the time we get here,
so the iscrollview.js should recognize the data-trim attribute which I've applied
earlier in index.html but unfortunately this doesn't happen in this implementation. /*
});
我希望我已经很好地指出了我的问题,以便你们出去。非常感谢您为此付出的努力!
编辑:
您可以在此处找到(简化的)项目。