- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 API(更准确地说是 Youtube API...)来获取视频标题。
所以我基本上创建了一个函数来调用 API 并获得我正在寻找的答案。之后,我希望能够获取该结果并将其返回到 tableCellView 中。
获取信息很好,一切正常。但是当我想获取信息并将其返回时,出现了问题。
这是我的功能:
func fetchData(userCompletionHandler: @escaping (String?, Error?) -> Void){
var yUrl = URL(string: youtubeUrlForRequest)
let task = URLSession.shared.dataTask(with: yUrl!) { (data, yresponse, yerror) in
do {
if let jsonResult = try JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.allowFragments) as? [String : AnyObject] {
if var items = jsonResult["items"] as? [AnyObject]? {
var snippetDict = items?[0]["snippet"] as! [String: AnyObject]
var titleVideo = snippetDict["title"] as! String
userCompletionHandler(titleVideo, nil)
}
}
}
catch {
print("json error: \(error)")
}
}
task.resume()
}
所以上面的部分没问题。
这是我调用函数的方式:
fetchData ( userCompletionHandler: { (ytitle, yerror) in
//var untitre = ""
guard let untitle = ytitle else{
print("Ok I'm in!!!")
//untitle = ytitle
//print(untitle)
return
}
print("OK HERE!!!!!!!!")
print(untitle)
})
//var test_titre = "Le titre est: " + bontitre
print(untitle)
return ()
所以 print("OK HERE!!!!!!!!!")
下的 print(untitle)
没问题,我确实得到了我想要的数据。
但是 return()
上的 print(untitle)
不会打印相同的内容。它将打印我在上面创建时赋予 untitle
的值:
var untitle: String = "a"
我的目标是能够让 return(untitle)
带有 return()
现在所在的视频标题。
最佳答案
在 DispatchGroup 的帮助下,我终于设法获取我想要的信息,以确保在执行某些操作之前每条信息都已存在。
上面的代码与下面的代码之间的主要区别在于,操作的顺序改变了一切。因此,在我的旧代码中,我曾经要求刷新我的 tableView 并在该刷新函数中,然后调用 Youtube API。这种设置让我陷入了瓶颈。因此,经过一些建议(谢谢大家!),我决定首先调用 API 并将结果存储在一个新数组中。一旦一切准备就绪(在 DispatchGroup 的帮助下),我将使用新数组的数据刷新 tableView。
这里是(大部分)我的不同功能的新代码(有些链接到用户界面上的按钮或其他内容):
let youtubeUrl = "https://www.googleapis.com/youtube/v3/videos?part=contentDetails%2C+snippet%2C+statistics&id="
//"AKiiekaEHhI&key="
var youtubeUrlForRequest:String = ""
let dispatchGroup = DispatchGroup()
var test_title: Array<String> = []
//func
@IBAction func plus(_ sender: NSButton) {
if urlInput.stringValue == "" {
} else {
if valeurEndroit.indexOfSelectedItem == -1{
print("coucou!")
test_text = urlInput.stringValue
test_data.append(test_text)
dispatchGroup.enter()
fetchData2(lien: test_data.last!, userCompletionHandler: {data_y, user_y, error_y in
if let user_y = user_y{
self.test_title.append(user_y)
self.dispatchGroup.leave()
}
})
dispatchGroup.notify(queue: .main) {
//print(untitle)
print("J'ai fini la liste de titre. Voici la liste: ")
//print(self.test_title)
self.urlInput.stringValue = ""
print(self.test_title)
self.tableView.reloadData()
}
//tableView.reloadData()
}else{
if valeurEndroit.indexOfSelectedItem >= test_data.count{
test_text = urlInput.stringValue
test_data.append(test_text)
dispatchGroup.enter()
fetchData2(lien: test_data.last!, userCompletionHandler: {data_y, user_y, error_y in
if let user_y = user_y{
self.test_title.append(user_y)
self.dispatchGroup.leave()
}
})
dispatchGroup.notify(queue: .main) {
//print(untitle)
print("J'ai fini la liste de titre. Voici la liste: ")
//print(self.test_title)
self.urlInput.stringValue = ""
print(self.test_title)
self.tableView.reloadData()
}
}else{
var y_index = (valeurEndroit.indexOfSelectedItem)
test_text = urlInput.stringValue
test_data.insert(test_text, at: valeurEndroit.indexOfSelectedItem)
dispatchGroup.enter()
fetchData2(lien: test_data[y_index], userCompletionHandler: {data_y, user_y, error_y in
if let user_y = user_y{
self.test_title.insert(user_y, at : y_index)
self.dispatchGroup.leave()
}
})
dispatchGroup.notify(queue: .main) {
//print(untitle)
print("J'ai fini la liste de titre. Voici la liste: ")
//print(self.test_title)
self.urlInput.stringValue = ""
print(self.test_title)
self.tableView.reloadData()
}
}
}
// fonction du bouton +
}
}
@IBAction func nextLien(_ sender: NSButton) {
if test_data == [] {
} else {
nextUrl=test_data[0]
var monUrl = URL(string: nextUrl)
var maRequete = URLRequest(url: monUrl!)
view_web.load(maRequete)
test_data.remove(at: 0)
test_title.remove(at: 0)
tableView.reloadData()
//fonction du bouton pour le prochain lien
}
}
@IBAction func openUnFichier(_ sender: NSMenuItem) {
let fichierPanel: NSOpenPanel = NSOpenPanel()
fichierPanel.allowsMultipleSelection = false
fichierPanel.canChooseFiles = true
fichierPanel.canChooseDirectories = false
fichierPanel.allowedFileTypes = ["txt"]
let response = fichierPanel.runModal()
if response == NSApplication.ModalResponse.OK{
guard let selectedURL = fichierPanel.url else{return}
do{
var fullDocument = try String(contentsOf: selectedURL, encoding: String.Encoding.utf8)
var lines : [String] = fullDocument.components(separatedBy: "\n" as String)
for line in lines {
test_data.append(line)
dispatchGroup.enter()
fetchData2(lien: test_data.last!, userCompletionHandler: {data_y, user_y, error_y in
if let user_y = user_y{
self.test_title.append(user_y)
self.dispatchGroup.leave()
}
})
dispatchGroup.notify(queue: .main) {
//print(untitle)
print("J'ai fini la liste de titre. Voici la liste: ")
//print(self.test_title)
self.urlInput.stringValue = ""
print(self.test_title)
self.tableView.reloadData()
}
}
} catch let error as NSError{
print("Erreur!!!!!!! \(error)")
}
//tableView.reloadData()
}else {
}
}
func numberOfRows(in tableView: NSTableView) -> Int {
return test_title.count
}
func tableView(_ tableView: NSTableView, objectValueFor tableColumn: NSTableColumn?, row: Int) -> Any? {
return (test_title[row])
}
func fetchData2(lien: String, userCompletionHandler: @escaping (String?, String?, Error?) -> Void){
var titleLien: String = ""
var urlToExtract_y = lien
var videoID_y = urlToExtract_y.components(separatedBy: "=")[1]
var youtubeUrlForRequest_y = youtubeUrl + videoID_y + "&key=" + youtubeApiKey
print(youtubeUrlForRequest_y)
var Url_y = URL(string: youtubeUrlForRequest_y)
var titleVideo_y = ""
let task_y = URLSession.shared.dataTask(with: Url_y!) { (data_y, response, error_y) in
do {
if let jsonResult_y = try JSONSerialization.jsonObject(with: data_y!, options: JSONSerialization.ReadingOptions.allowFragments) as? [String : AnyObject] {
if var items_y = jsonResult_y["items"] as? [AnyObject]? {
var snippetDict_y = items_y?[0]["snippet"] as! [String: AnyObject]
var titleVideo_y = snippetDict_y["title"] as! String
userCompletionHandler(titleVideo_y, titleVideo_y, nil)
}
}
}
catch {
print("json error: \(error_y)")
}
}
task_y.resume()
}
//var Outlet
@IBOutlet weak var urlInput: NSTextField!
@IBOutlet weak var view_web: WKWebView!
@IBOutlet weak var tableView: NSTableView!
@IBOutlet weak var valeurEndroit: NSComboBox!
有些部分没有粘贴到这里,因为它对于理解来说并不重要或者很敏感(例如 YouTube API key )。
关于swift - 无法从外部 userCompletionHandler 访问值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56407689/
我需要为打开的 xlsx 文件取消隐藏工作表 TAB,为此,我使用 VBS 文件打开 xlsm 文件并激活宏(位于模块中)。 当我手动运行宏时,它可以工作。 当它通过vbs激活时,它只能看到包含宏的x
我正在使用 Google Cloud Compute Engine 安装气流并使其保持正常运行。安装很好,现在它在主机上运行:0.0.0.0:8080 我有此 VM 实例的外部 IP 地址,但是我无法
我们可以在 GWT 中使用这个 $entry 方法来允许外部 javascript 执行 java 方法。 你可以在他们的文档 https://developers.google.com/web-to
在 Cython 的“Hello World”和 C 数学库中调用函数的示例之后 here ,我真正想做的是将我自己的 C 代码放在一个单独的文件中,并在 Cython 中使用它。关注 this ,我
我一直在试验 JSON Pointers引用和重用 JSON schemas . 按照示例,我能够引用在另一个 JSON 模式中声明的特定属性,一切都按预期进行,但是我还没有找到一种方法来扩展基本 J
我正在使用 X.jar 并添加到我的 AspectJ 项目(在 eclipse 中)。我已经为 X.jar 中的 myMethod() 方法编写了切入点和建议。 但是aspectj 并没有拦截这个方法
我正在 Controller 中创建一个自定义指令,并在 ng-repeat 中调用它,如下所示: HTML: JS: 在测试指令中,我按如下方式调用 loadDat
我正在尝试加载服务器上本地存在的 HTML 页面,位于名为 HTML-FIles 的文件夹中。 我想使用 jquery 加载一个文件并将其内容显示在 div 中。 现在,我可以加载文件,但在 div
我正在尝试根据初始选择从 JSON 文件生成选择菜单。我见过很多不同的方式,人们为此编写了一个函数,但想要一些非常简单的东西。 HTML: Please select Practis
我的目标是从 HTML 文档中获取文本,该文档不会调用 .jsp 文件中的任何函数。 我环顾四周,我以为我已经找到了问题的答案,但它似乎不起作用,其他答案包括使用 jQuery(我既不熟悉也不允许使用
我正在尝试从外部 JSON 文件获取文件内容,但我一直在警报中收到 null。 JS: function getText() { var result = null; var file
我正在加载一个外部 javascript 文件,该文件仅填充有 int 或字符串或 bool 值或数组的变量。类似... varBool=false; var1="var1"; var2="var2:
我的数据存储在外部 Javascript 文件中。 看起来像这样, window.videos = [{ "name": "Sample data", "duration": 154,
我有一个包含 Google ADWords 的 HTML 页面,以及来自外部 URL 的 ajax 调用,我想获取 json 来自 url 的数据。外部API也是我做的。API Controller
我试图看看是否有一种简单的方法可以通过外部 JavaScript 函数访问 Controller 的内部范围(与目标 Controller 完全无关) 我在这里看到了其他几个问题 angular.el
我尝试在运行外部命令时终止脚本,结果出现错误。考虑这个简单的代码: try { where.exe Test-App } catch { Write-Error "Exception
我在 test.js 中定义了一个外部 JS 函数 function InvokeSupport(ID, TimeStamp, Hash) { var sUrl = '' + "?uid="
如果我想将变量从外部 js 文件提取到另一个外部 js 文件。我该怎么做? 例如,如果我有一个名为 example1.js 的文件,其中包含以下代码 var test = 1; 如何获取变量 tes
我正在尝试使用 java 从外部 jar 中读取文件..例如,我有两个 jar 文件。一个是“foo.jar”,另一个是“bar.jar”。 “bar.jar”内部是文件“foo-bar.txt”。如
在我的 Java 应用程序中,我希望从未实际加载的类文件以及也未加载的 jar 文件中读取字节码内容。理想情况下,我需要能够获取任何给定的 jarfile,并找到其中的所有类。因此,考虑以下情况: 我
我是一名优秀的程序员,十分优秀!