Nativescript - 将边框添加到Actionbar

时间:2018-02-21 09:12:10

标签: nativescript angular2-nativescript

大家好我有问题, 我想在顶部添加红色边框到我的操作栏 这是我的代码 -

<ActionBar class=" border-top"  title="" loaded="loaded" >
    <NavigationButton ></NavigationButton>
    <ActionBar.actionItems  >
        <ActionItem ios.position="right" >
            <ActionItem.actionView>
                <AbsoluteLayout >
                <Label text="&#xf145;" class="action-item gray" />
                </AbsoluteLayout>
            </ActionItem.actionView>
        </ActionItem>
        <ActionItem ios.position="right" >
            <ActionItem.actionView>
                <AbsoluteLayout  class="{{ selectedPage ==='contacts' ? 'higlight-menu-item':'' }}">
                    <Label text="&#xf0c0;" 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

但我不知道如何写它? 我尝试了几天,但没有解决方案,有人可以帮助一点?

1 个答案:

答案 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);
    }

希望它可以帮助某人:)