大家好我有问题, 我想在顶部添加红色边框到我的操作栏 这是我的代码 -
<ActionBar class=" border-top" title="" loaded="loaded" >
<NavigationButton ></NavigationButton>
<ActionBar.actionItems >
<ActionItem ios.position="right" >
<ActionItem.actionView>
<AbsoluteLayout >
<Label text="" class="action-item gray" />
</AbsoluteLayout>
</ActionItem.actionView>
</ActionItem>
<ActionItem ios.position="right" >
<ActionItem.actionView>
<AbsoluteLayout class="{{ selectedPage ==='contacts' ? 'higlight-menu-item':'' }}">
<Label text="" class="action-item gray" />
</AbsoluteLayout>
</ActionItem.actionView>
</ActionItem>
</ActionBar.actionItems>
</ActionBar>
和我的app.css
.border-top {
border-top-color:#ec295f;
border-top-width:2;
}
这在Android设备上运行正常,但在IOS上却没有显示 似乎没有开箱即用的IOS解决方案 我在这里找到了问题 https://github.com/NativeScript/NativeScript/issues/5395
https://github.com/NativeScript/NativeScript/issues/2470#issuecomment-233555881
但我不知道如何写它? 我尝试了几天,但没有解决方案,有人可以帮助一点?
答案 0 :(得分:0)
Nativescript中没有解决方案,因此我必须访问IOS的本机方法并编写自己的解决方案。 这是我的解决方案:
var colorModule = require("color");
var red = new colorModule.Color("#ec295f");
const frameModule = require('ui/frame');
if (frameModule.topmost().ios) {
let controller = frameModule.topmost().ios.controller;
let navBar = controller.navigationBar;
let border = new UIView(CGRectMake(0, 1, navBar.frame.size.width, 2));
border.backgroundColor = UIColor(red.ios);
border.opaque = true;
navBar.addSubview(border);
}
希望它可以帮助某人:)