目前我使用uiwebview上的按钮返回用户搜索的每个网页,并且其工作效果很好。但是,无论如何使用导航栏后退按钮返回以前的网页,当没有更多页面返回时再打开上一个视图控制器?
下面的代码是我用来返回刚刚连接到UIButton的代码。
// Back button events
func onBackButton_Clicked(sender: UIButton)
{
if(webview.canGoBack)
{
webview.goBack()
}
}
任何帮助都会很棒。
答案 0 :(得分:19)
添加到您的代码中,您可以添加一个在没有更多Web历史记录时运行的其他内容并弹出视图控制器,这将返回到上一个视图控制器(如果您在导航控制器中查看控制器):
if(webview.canGoBack) {
//Go back in webview history
webview.goBack()
} else {
//Pop view controller to preview view controller
self.navigationController?.popViewControllerAnimated(true)
}
此外,如果您要删除默认后退按钮并使用自定义按钮,请在ViewDidLoad中添加此代码:
self.navigationItem.backBarButtonItem = UIBarButtonItem(image: image, style: UIBarButtonItemStyle.Plain, target: self, action: "onBackButton_Clicked:")
并改变上述方法:
onBackButton_Clicked(sender: UIButton)
为:
onBackButton_Clicked(sender: UIBarButtonItem)
答案 1 :(得分:4)
我建议重载后退按钮功能并检查历史记录。
override func viewDidLoad {
super.viewDidLoad()
self.navigationItem.hidesBackButton = true
let newBackButton = UIBarButtonItem(title: "Back", style: UIBarButtonItemStyle.Bordered, target: self, action: "back:")
self.navigationItem.leftBarButtonItem = newBackButton;
}
func back(sender: UIBarButtonItem) {
if(webview.canGoBack) {
webview.goBack()
} else {
self.navigationController.popViewController(animated:true)
}
}
答案 2 :(得分:0)
您需要使用BackBarButton
来
1.浏览以前的网页
2.从第一个加载的网页返回上一个控制器。
目前,后一个要求似乎满足于NavigationBar上的BackButton。您要做的是添加自定义BackButton
。
override func viewDidLoad()
{
super.viewDidLoad()
leftButton = UIButton(type: UIButtonType.Custom)
leftButton.frame = CGRectMake(0, 0, 36, 36)
leftButton.clipsToBounds = true
leftButton.setImage(UIImage(named: "yourBackButton.png"), forState: .Normal) // add custom image
leftButton.addTarget(self, action: "onBackButton_Clicked:", forControlEvents: UIControlEvents.TouchUpInside)
let leftBarButton = UIBarButtonItem()
leftBarButton.customView = leftButton
self.navigationItem.leftBarButtonItem = leftBarButton
}
func onBackButton_Clicked(sender: UIButton)
{
if(webview.canGoBack) {
webview.goBack()
}
else {
self.navigationController.popViewController(animated: true)
}
}