- IQKeyboardManager
- 不显示上下箭头
因为textFied的父视图中只有一个textField - TextField上移时,导航栏也跟着上移,效果很不好
重写控制器的loadView方法
- (void)loadView {
UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:[UIScreen mainScreen].bounds];
scrollView.contentSize = CGSizeMake(kScreenWidth, kScreenHeight);
self.view = scrollView;
}
- 出现textField不上移
不能直接将textField添加在scrollView上,可以创建一个containerView添加在scrollView上,然后再加textField添加在containerView上,这样就不会出现以上错误啦~
- 项目在App Store中显示本地化语言
在info.plist文件中修改
key --> Localization native development region
value --> th_TH (日本是ja_JP,ja是日本语,JP是日本,iso标准)
- iOS 11相册里面添加图片程序崩溃或者不弹隐私权限导致保存图片失败
需要添加iOS 11新增权限
Privacy - Photo Library Additions Usage Description "添加图片到相册"
- 推送问题
- 应用处于活跃状态下通知弹出,目前只支持IOS10+,IOS10以下的版本只会在后台或者程序处于杀死状态的时候才会展示。
-
在info.plist文件下UIBackground Modes remote-notification
当应用处于后台或者挂起模式下,收到通知,会自动调用
- (void)application:(UIApplication *)application
didReceiveRemoteNotification:(NSDictionary *)userInfo
fetchCompletionHandler:(void (^)(UIBackgroundFetchResult result))
completionHandler NS_AVAILABLE_IOS(7_0);
Masonry布局,获取视图的frame为0
参考资料:
http://www.jianshu.com/p/ad9c075a7547button无响应
因为添加的父视图的frame不确定...button的图片颜色变为了蓝色???
button的类型造成的,如果设置为UIButtonTypeSystem,就会变为蓝色...tableView reloadData的时候会跳动
iOS11默认开启Self-Sizing 如果你没用到预估高度 那么你尝试在Appdelegate.m中的didFinishLaunchingWithOptions方法中,加上如下代码,看看是否有效
if (@available(iOS 11.0, *)) {
UITableView.appearance.estimatedRowHeight = 0;
UITableView.appearance.estimatedSectionFooterHeight = 0;
UITableView.appearance.estimatedSectionHeaderHeight = 0;
}
- sizeToFit 和 sizeThatFits的使用区别
sizeToFit:会计算出最优的 size 而且会改变自己的size
sizeThatFits:会计算出最优的 size 但是不会改变 自己的 size
sizeToFit
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(10, 10, 0, 0)];
[label setBackgroundColor:[UIColor grayColor]];
[label setFont:[UIFont systemFontOfSize:20]];
label.text = @"北京欢饮您!!!";
//sizeToFit:直接改变了这个label的宽和高,使它根据上面字符串的大小做合适的改变
[label sizeToFit];
NSLog(@"width=%.1f height=%.1f ", label.frame.size.width, label.frame.size.height);
[self.view addSubview:label];
sizeThatFits
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(10, 10, 0, 0)];
[label setBackgroundColor:[UIColor grayColor]];
[label setFont:[UIFont systemFontOfSize:20]];
label.text = @"北京欢饮您!!!";
//sizeThatFits并没有改变原始label的大小
CGSize sizeThatFits = [label sizeThatFits:CGSizeZero];
NSLog(@"sizeThatFits: width=%.1f height=%.1f", sizeThatFits.width, sizeThatFits.height);
NSLog(@"width=%.1f height=%.1f", label.frame.size.width, label.frame.size.height);
[self.view addSubview:label];
sizeToFit:会计算出最优的 size 而且会改变自己的size
sizeThatFits:会计算出最优的 size 但是不会改变 自己的 size
- 微信支付注意事项
- 系统版本大于等于iOS9的,调起微信客户端之后,可以直接点击状态栏左侧按钮返回,这时是不走回调方法的。
这样在支付成功之后,不走回调方法,就无法知道支付状态,当前页面无法给出提示。
解决方案是,在AppDelegate.m的applicationWillEnterForeground方法中,调用查询支付结果接口然后刷新当然页面。需要设置bool变量作为标志,否则每次应用进入前台都去查询,就不符合业务要求了。 - 进入微信支付页面之后,不做操作,切换到自己应用中,退出当前支付页面,然后再进入微信客户端点击支付或者取消,此时自己的应用会崩溃闪退
原因是退出页面后页面已经出栈被销毁,但wx回调时还是去调用其中的代理方法,就会出现野指针。
解决方法是,在页面的viewWillDisappear方法中加入
[PaymentManager sharedManager].delegate = nil;
- 微信支付的单位是分
- 白名单:不配置白名单也可以调起支付,如果调不起支付,查看是否是白名单的问题。
打开工程里的info.plist文件 添加LSApplicationQueriesSchemes数组并添加wechat 和 weixin字符串。
或者info.plist右键->source code打开添加下面这段代码
<key>LSApplicationQueriesSchemes</key>
<array><string>wechat</string>
<string>weixin </string>
</array>
- 在需要微信支付的地方调用封装的类方法之后会跳转到微信app,如果没有安装则没有任何反应。这里需要注意,因为没有安装微信,必须要提供webview的方式登录微信来支付,否则苹果公司会拒绝应用上架。但是微信又不自带webview的方式,(支付宝是自带的)所以要判断用户有没有安装微信,如果没有安装微信就不显示微信支付这个按钮
- iOS textField长按出现select,selectall 选择显示成中文全选黏贴 剪切、复制、选中的提示为英文改为中文
解决办法:
1.首先保证手机系统是简体中文: 设置->通用->语言与地区
2.项目的info.plist文件中,增加 sorcecode是这样的,
<key>CFBundleLocalizations</key>
<array>
<string>en</string>
<string>zh_CN</string>
</array>
- 开启关闭右滑手势
@interface YBRLoginViewController : UIViewController<UIGestureRecognizerDelegate>
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
self.navigationController.interactivePopGestureRecognizer.delegate = self;
self.navigationController.interactivePopGestureRecognizer.enabled = YES;
}
- (void)viewDidAppear:(BOOL)animated
{
[super viewDidAppear:animated];
// 禁用返回手势
if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) {
self.navigationController.interactivePopGestureRecognizer.enabled = NO;
}
}
- (void)viewWillDisappear:(BOOL)animated
{
[super viewWillDisappear:animated];
self.navigationController.navigationBarHidden = NO;
// 开启返回手势
if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) {
self.navigationController.interactivePopGestureRecognizer.enabled = YES;
}
}
@end