uniapp用webview写入配置缓存
时间: 2023-10-16 21:08:20 浏览: 143
在uniapp中使用webview写入配置缓存的方法如下所示:
首先,你需要在uniapp的webview组件中设置一些函数。你可以使用以下代码来设置webview的配置:
```javascript
mWebView = (WebView) this.findViewById(R.id.webview);
WebSettings settings = mWebView.getSettings();
settings.setJavaScriptEnabled(true);
settings.setDomStorageEnabled(true);
mWebView.getSettings().setAppCacheMaxSize(1024*1024*8);
String appCachePath = getApplicationContext().getCacheDir().getAbsolutePath();
mWebView.getSettings().setAppCachePath(appCachePath);
mWebView.getSettings().setAllowFileAccess(true);
mWebView.getSettings().setAppCacheEnabled(true);
```
这些设置将启用JavaScript,并开启本地缓存以供JS调用。
接下来,你可以在webview的onPageFinished方法中写入配置缓存。你可以使用以下代码来实现:
```java
private boolean inWrited = false;
webView.setWebViewClient(new WebViewClient(){
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
if(!inWrited){
setData(webView);
inWrited = true;
}
}
});
private void setData(WebView mWebView) {
//拼接 JavaScript 代码
String key= "userInfo";
User user = new User();
user.setName("Vicent");
user.setPhone(18888886666);
String value = new Gson().toJson(user);
String js = "window.localStorage.setItem('"+key+"','" + value + "');";
String jsUrl = "javascript:(function(){ var localStorage = window.localStorage; localStorage.setItem('"+key+"','" + value + "') })()";
//根据不同版本,使用不同的 API 执行 Js
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
mWebView.evaluateJavascript(js, null);
} else {
mWebView.loadUrl(jsUrl);
mWebView.reload();
}
}
```
在setData方法中,我们使用JavaScript代码将配置数据写入localStorage。然后,根据不同的Android版本,使用不同的API来执行JavaScript代码。
这样,你就可以在uniapp中使用webview写入配置缓存了。希望对你有所帮助!
#### 引用[.reference_title]
- *1* *3* [WebView写入数据到 localStorage总结](https://blog.csdn.net/Vicent_9920/article/details/77281727)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [uniapp通过webview调用H5页面](https://blog.csdn.net/qq_43344133/article/details/106871461)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文