- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我希望 UITableView
的单元格在 iOS 10 和 11 中适应其内容的大小:
tableView.estimatedRowHeight = UITableViewAutomaticDimension // default in iOS 11
tableView.rowHeight = UITableViewAutomaticDimension
没有将 tableView.rowHeight
设置为明确的数值,这是 iOS 11 中的新默认值。
UIView
没有固有的内容大小,因此我为其高度 anchor 设置了布局约束。然而,该 anchor 在运行时中断。
UITableViewCell
中的哪些内部约束对于单元格适应其内容是必要的?
这仅适用于 iOS 11:
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
override func viewDidLoad() {
super.viewDidLoad()
let tableView = UITableView()
tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cell")
tableView.estimatedRowHeight = UITableViewAutomaticDimension
tableView.rowHeight = UITableViewAutomaticDimension
tableView.delegate = self
tableView.dataSource = self
tableView.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(tableView)
NSLayoutConstraint.activate([
tableView.topAnchor.constraint(equalTo: view.topAnchor),
tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor),
tableView.leftAnchor.constraint(equalTo: view.leftAnchor),
tableView.rightAnchor.constraint(equalTo: view.rightAnchor)
])
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = UITableViewCell(style: UITableViewCellStyle.subtitle, reuseIdentifier: "cell")
let view = UIView()
view.backgroundColor = .blue
view.translatesAutoresizingMaskIntoConstraints = false
cell.contentView.addSubview(view)
NSLayoutConstraint.activate([
view.topAnchor.constraint(equalTo: cell.contentView.topAnchor),
view.bottomAnchor.constraint(equalTo: cell.contentView.bottomAnchor),
view.leftAnchor.constraint(equalTo: cell.contentView.leftAnchor),
view.rightAnchor.constraint(equalTo: cell.contentView.rightAnchor),
view.heightAnchor.constraint(equalToConstant: 300)
])
return cell
}
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 1
}
}
在 iOS 10 中它抛出这个运行时错误并且单元格大小不适应:
[LayoutConstraints] Unable to simultaneously satisfy constraints. Probably at least one of the constraints in the following list is one you don't want. Try this: (1) look at each constraint and try to figure out which you don't expect; (2) find the code that added the unwanted constraint or constraints and fix it. ( "NSLayoutConstraint:0x17009c020 V:|-(0)-[test.MyView:0x11dd1acb0] (active, names: '|':UITableViewCellContentView:0x11dd15220 )", "NSLayoutConstraint:0x17009c160 test.MyView:0x11dd1acb0.bottom == UITableViewCellContentView:0x11dd15220.bottom (active)", "NSLayoutConstraint:0x17009c390 test.MyView:0x11dd1acb0.height == 300 (active)", "NSLayoutConstraint:0x17009be40 'UIView-Encapsulated-Layout-Height' UITableViewCellContentView:0x11dd15220.height == 43.6667 (active)" )
Will attempt to recover by breaking constraint NSLayoutConstraint:0x17009c390 test.MyView:0x11dd1acb0.height == 300 (active)
Make a symbolic breakpoint at UIViewAlertForUnsatisfiableConstraints to catch this in the debugger. The methods in the UIConstraintBasedLayoutDebugging category on UIView listed in UIKit/UIView.h may also be helpful.
这在 iOS 10 和 11 中有效,但不使用新的 iOS 11 方法,因为 tableView.estimatedRowHeight
不是 UITableViewAutomaticDimension
:
class ViewController_TableView: UIViewController, UITableViewDataSource, UITableViewDelegate {
override func viewDidLoad() {
super.viewDidLoad()
let tableView = UITableView()
tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cell")
tableView.estimatedRowHeight = 30
tableView.rowHeight = UITableViewAutomaticDimension
tableView.delegate = self
tableView.dataSource = self
tableView.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(tableView)
NSLayoutConstraint.activate([
tableView.topAnchor.constraint(equalTo: view.topAnchor),
tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor),
tableView.leftAnchor.constraint(equalTo: view.leftAnchor),
tableView.rightAnchor.constraint(equalTo: view.rightAnchor)
])
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = UITableViewCell(style: UITableViewCellStyle.subtitle, reuseIdentifier: "cell")
let view = MyView()
view.backgroundColor = .blue
view.translatesAutoresizingMaskIntoConstraints = false
cell.contentView.addSubview(view)
NSLayoutConstraint.activate([
view.topAnchor.constraint(equalTo: cell.contentView.topAnchor),
view.bottomAnchor.constraint(equalTo: cell.contentView.bottomAnchor),
view.leftAnchor.constraint(equalTo: cell.contentView.leftAnchor),
view.rightAnchor.constraint(equalTo: cell.contentView.rightAnchor)
])
return cell
}
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 1
}
}
class MyView: UIView {
override var intrinsicContentSize: CGSize {
get {
return CGSize(width: 300, height: 300)
}
}
}
最佳答案
您没有使委托(delegate)符合您的 Controller 。然后使用代码
class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
let params : [String: Any] = ["q": "dd", "format": "json", "pretty": 1,"no_html": 1, "skip_disambig": 1]
Alamofire.request("https://api.duckduckgo.com", method: .get, parameters: params).responseJSON { (responseData) in
print(responseData)
}
let tableView = UITableView()
tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cell")
tableView.estimatedRowHeight = 40
tableView.delegate = self
tableView.dataSource = self
tableView.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(tableView)
NSLayoutConstraint.activate([
tableView.topAnchor.constraint(equalTo: view.topAnchor),
tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor),
tableView.leftAnchor.constraint(equalTo: view.leftAnchor),
tableView.rightAnchor.constraint(equalTo: view.rightAnchor)
])
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = UITableViewCell(style: UITableViewCellStyle.subtitle, reuseIdentifier: "cell")
let view = UIView()
view.backgroundColor = .blue
view.translatesAutoresizingMaskIntoConstraints = false
cell.contentView.addSubview(view)
NSLayoutConstraint.activate([
view.topAnchor.constraint(equalTo: cell.contentView.topAnchor),
view.bottomAnchor.constraint(equalTo: cell.contentView.bottomAnchor),
view.leftAnchor.constraint(equalTo: cell.contentView.leftAnchor),
view.rightAnchor.constraint(equalTo: cell.contentView.rightAnchor),
view.heightAnchor.constraint(equalToConstant: 300) // this breaks on run time
])
return cell
}
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 1
}
// use this delegate
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
return UITableViewAutomaticDimension
}
}
关于iOS 11 : Adapt cell size to content with UITableViewAutomaticDimension,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46542029/
我有一个 TableView ,其中包含由代码创建的动态单元格。 在 IOS 7 中,为了确保单元格完全显示,我覆盖了方法 heightForRowAtIndexPath 在 ios8 中覆盖这个方法
我正在使用 UITableViewAutomaticDimension 制作 TableView 但由于某种原因,最后一个空白单元格之后的“额外”空白单元格与最后一个带有文本的单元格的尺寸相同。我希望
我的表格有这段代码 (_filters = UITableView) - (void)viewDidLoad { // table data set here ... _filters
我正在制作一个带有文本帖子的应用程序,但我意识到很多文本帖子会很长,所以我添加了一个显示全部和更少按钮,但是当你按下它时,有时单元格会消失,你向上滚动然后它跳到单元格的中间。这是它的样子,因为它很难解
我有一个显示所有用户更新的 feedVC。我正在从 firebase 检索数据,并希望根据帖子长度自动设置高度。问题是,即使从 heightForRowAt 返回 UITableViewAutomat
我有一个项目使用 iOS 的默认动态字体。因此,我使用 UITableViewAutomaticDimension 作为高度。我以编程方式执行所有操作,因此我为我的自定义单元格设置了约束。 我对约束和
我的 Swift 项目中有这样一张表 var tableView: UITableView! tableView = UITableView() tableView.dataSource = self
图像显示在其中一个单元格中。 图像的约束条件如下: heightForRow 中此单元格的高度设置为 UITableViewAutomaticDimension。但是图像从底部被砍掉了。如何解决这个问
我添加了一个表格 View ,我在单元格中显示图像。我还添加了这段代码: tableView.estimatedRowHeight = 175 tableView.rowHeight = UITabl
关于 UITableView 的 UITableViewCell 的动态高度有很多问题。但是我无法解决我的问题。 我有这个表格单元格创建代码: class UINoteTabelViewCell: U
我正在以编程方式为日历应用程序制作一个表格 View ,并且需要根据它们包含的文本调整我的表格 View 单元格的大小。我正在尝试使用自动布局,但由于某种原因我无法让它工作 - (void)view
我很难处理动态高度自定义 tableView 单元格。 所以我得到了“无法同时满足约束条件。”警告(但只是有时,就像千分之一) 我认为 UITableViewAutomaticDimension 给出
好的,我在使用 tableview 创建动态单元格时遇到了问题。我的图像崩溃了,看起来像这样。当描述很长时效果很好,但当描述很短时效果不佳。 图像约束为:width = 120,height = 16
我正在尝试使用 UITableViewAutomaticDimension,但我无法在不引起 NSLayoutAutomaticSizeConstraint... 问题的情况下让单元格具有完整宽度和正
我对 UITableViewAutomaticDimension 有疑问: 在我的表格 View 中,我有多个以编程方式创建的 ImageView ,它们具有计算的高度: override func
我在 tableView 中使用 UITableViewAutomaticDimension 并且它工作正常,但是当加载表时,我需要单元格的行大小。表的。可能吗? 提前致谢。 最佳答案 使您的 Vie
只要我不尝试启用自动调整大小,我的单元格就可以正常显示。当我在我的 viewController 中添加用于自动调整大小的两行时,个人资料图片、用户名和日期下的所有内容都会消失(该单元格应该看起来像
是否可以为单元格设置最小高度?我使用动态: tableView.estimatedRowHeight = 83.0 tableView.rowHeight = UITableViewAutomatic
首次加载 TableView 时,所有可见单元格都是估计的行高。当我向下滚动时,单元格会自动调整大小,当我向上滚动时,最初 estimatedRowHeight 的单元格会自动调整大小。 一旦单元格自
我试图将最后一个tableView行的高度设置为与其他行不同。我不想创建一个新的单元格等,而是想从该单元格的高度“剪切”10px。由于我设置了高度的自动尺寸,因此无法使用恒定值。 它是这样的: tab
我是一名优秀的程序员,十分优秀!