在我的项目中,首先,我从数据库中获取了几个字符串,然后我将每个字符串标记为<li>
,并通过调用javascript函数将它们附加到空<ul>
中。每当我修改代码并运行它时,第一次,js函数似乎没有被执行,但当我再次运行它时,js工作,所有字符串都被添加到<ul>
<li>
。只要我从未修改过代码,app就可以正常工作,这意味着如果我在移动设备上重新安装它,js就无法工作,直到第二次打开这个应用程序。数据库的东西没什么问题。我认为问题是webview是在js执行之前绘制的,然后当webview重新绘制时,一切都很顺利。
这是我的activity.java
public class WebView_testActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
WebView web = (WebView)findViewById(R.id.web_content);
webView_handler(web);
data_handler(web);
Log.d(MyLog.LOG, "end of file");
}
private void webView_handler(WebView web){
web.loadUrl("file:///android_asset/FormPanel.html");
web.getSettings().setJavaScriptEnabled(true);
}
private void data_handler(WebView web){
boolean hasSD = Environment.getExternalStorageState().equals( android.os.Environment.MEDIA_MOUNTED);
//String SDPATH = Environment.getExternalStorageDirectory().getPath();
if(hasSD){
DbHelper data_helper = new DbHelper(this, "/mnt/sdcard/CTIL/QuestionDB/Q1.db");
SQLiteDatabase database = data_helper.getReadableDatabase();
String sql = "SELECT pe.Description FROM tblFormEngine_PoolElement pe " +
"NATURAL JOIN tblFormEngine_FormElement fe WHERE fe.PanelID = 1";
Cursor c = database.rawQuery(sql,null);
if(c.getCount() == 0)
Log.d(MyLog.LOG, "empty");
c.moveToFirst();
if(!c.isAfterLast()){
do{
String description = c.getString(0);
String html = "<li><p>" + description + "</p></li>";
Log.d(MyLog.LOG, html);
//web.loadUrl("javascript:Element_AppendHTML('content',\""+html+"\")");
MyThread mt = new MyThread(web, html);
mt.start();
}while(c.moveToNext());
}
c.close();
database.close();
}
}
private class MyThread extends Thread{
private WebView web;
private String html;
MyThread(WebView web, String html){
this.web = web;
this.html = html;
}
public void run(){
try {
web.loadUrl("javascript:Element_AppendHTML('content',\""+html+"\")");
sleep(500);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
这是js函数(它实际上是一个JQuery函数):
function Element_AppendHTML(ElementID,HTML)
{
$("#"+ElementID).append(HTML);
}
以下是您需要查看的原始HTML文件:
<html>
<head>
<title>Form Panel</title>
<meta charset="utf-8">
<link rel="stylesheet" href="theme/FormPanel_Basic.css">
<script type="text/javascript" src="js/jquery-1.5.1.js"></script>
<script type="text/javascript" src="js/jquery.scrollTo-1.4.2-min.js"></script>
<script type="text/javascript" src="js/jquery.scrollToMe.js"></script>
<script type="text/javascript" src="js/FormPanel.js"></script>
</head>
<body>
<ul id="content" selected="true">
</ul>
</body>
</html>
有什么建议吗?
答案 0 :(得分:2)
从
改变web.loadUrl("file:///android_asset/FormPanel.html");
web.getSettings().setJavaScriptEnabled(true);
到
web.getSettings().setJavaScriptEnabled(true);
web.loadUrl("file:///android_asset/FormPanel.html");
完成设置后,你不打电话给loadurl吗?