No installed build tools found. Install the Android build tools version
有时候,新电脑编译apk的时候会报这些错,这其实都是环境变量没配置好导致的
首先先找到自己的sdk安装位置

打开环境变量配置


%ANDROID_HOME%\platform-tools
%ANDROID_HOME%\tools
修改完终端记得关闭下软件再重新打开才可以生效,当然直接重启电脑也是没问题的
No installed build tools found. Install the Android build tools version
有时候,新电脑编译apk的时候会报这些错,这其实都是环境变量没配置好导致的
首先先找到自己的sdk安装位置
打开环境变量配置
%ANDROID_HOME%\platform-tools
%ANDROID_HOME%\tools
修改完终端记得关闭下软件再重新打开才可以生效,当然直接重启电脑也是没问题的
Could not resolve com.android.support:support-annotations:27.+
ionic 打包的时候
遇到这个问题的时候,ionic 编译会失败,出了更改版本外,还可以
找到所有的
build.gradle 加入这行就可以
repositories {
google()
maven { url "https://maven.google.com"}
maven { url "https://dl.google.com/dl/android/maven2/"}
}
背景:安卓中的 webView 要求实现 内嵌的 js 调用 安卓APP的方法 与并且支持安卓回调js代码 来实现。
WebView部分
webView.addJavascriptInterface(new JsInterface(this), "AndroidWebView"); //重要的
Java部分
@SuppressLint({“SetJavaScriptEnabled”, “AddJavascriptInterface”})
class JsInterface {
private Context mContext;
public JsInterface(Context context) {
this.mContext = context;
}
@JavascriptInterface
public String getName(){
return getUser();
}
@JavascriptInterface
public String getPass(){
return getPass();
}
Js部分
function loading(){
var name=window.AndroidWebView.getName()
var pass=window.AndroidWebView.getPass()//调用java方法
$.post(“101.111.11:800”,{remark:name,password:pass},function(result){
var obj=result;
if(obj.code==100){
toast(“登录成功”);
}else{
toast(“登录失败”);
}
});
}
来源: https://blog.csdn.net/u014548562/article/details/77916409
以上是我看博客的时候看到的,在angular中 我直接在html中写,发现不可以传变量过去,
例如:
<input onclick=”window.callJava.functionz(‘string’)”></input>
<input onclick=”window.callJava.functionz(parmString.toSring())”></input>
后来发现需要在ts代码中这样使用才可以。
相关文章链接:
1.Java执行JavaScript代码http://www.jb51.net/article/81577.htm
2.JAVA执行javascript方法http://blog.csdn.net/jianggujin/article/details/51046122
3.如何在java中调用js方法http://www.cnblogs.com/langtianya/archive/2012/09/18/2690860.html
<ion-avatar item-start><img src=”图片地址”></ion-avatar>
<ion-thumbnail item-end><img src=”图片地址”></ion-thumbnail>
这是typescript的类型检查导致的,需要在你的querySelectorAll方法前面加个类型断言就好了,如下
let block = document.querySelectorAll(".block") as NodeListOf<HTMLElement>;
参考
https://segmentfault.com/q/1010000011796234/a-1020000011796986
//ionic中当页面进入初始化的时候触发的生命周期方法
ionViewDidEnter(){
let elements = document.querySelectorAll(".tabbar");
if (elements != null) {
Object.keys(elements).map((key) => {
elements[key].style.display = 'none';
});
}
}
//ionic当退出页面的时候触发的方法
ionViewWillLeave() {
//这里注意 .tabbar 是选项卡的名字,如果要只隐藏部分选项卡,可以替换
let elements = document.querySelectorAll(".tabbar");
if (elements != null) {
Object.keys(elements).map((key) => {
elements[key].style.display = 'flex';
});
}
}
ionic4的话 参考这篇文章
<一句话教程>不要使用angular的管道,特别是列表中,推荐使用
{{CrtDate.substr(0,10)}}
替换
ionic3 如何禁用ios的滑动返回 只需要一行
IonicModule.forRoot(App, {tabsHideOnSubPages:’true’,//在子页面隐藏底部菜单swipeBackEnabled:false,//禁用ios的滑动返回}
ionic start myApp tabs --type=angular