Je suis passé à Xcode 6 beta 4 et maintenant, mon application se bloque continuellement avec le message
Classe X inconnue dans le fichier Interface Builder.
Il se bloque car Xcode ne peut apparemment pas trouver les classes personnalisées que j'ai liées dans mon Storyboard, mais il indique qu'elles sont correctement liées dans l'interface Xcode.
Je suis certain que tout est lié correctement. Ma seule autre option peut être de supprimer le fichier de storyboard en entier et de recommencer à zéro, car il pourrait être corrompu.
Edit: Je voudrais aussi ajouter que j'ai essayé de nettoyer, de réinitialiser le simulateur, de jouer avec les phases de construction, etc. Cela ne fonctionne pas.
J'ai résolu ce problème en tapant la question. Je pensais répondre à ma question et la laisser ici à quiconque pourrait être confronté à ce problème lors de l'utilisation de Xcode 6 beta 4.
Pour résoudre ce problème, vous devez sélectionner chacun de vos objets de classe personnalisés dans Storyboard (cela inclut toutes les vues personnalisées, même les contrôleurs de vue personnalisés eux-mêmes).
Ensuite, avec ces objets sélectionnés, ouvrez l'inspecteur d'identité et sous "Classe personnalisée", vous devriez voir l'option Module. Cliquez à l'intérieur de la zone de texte Module et appuyez sur entrée.
C'est tout! Le module actuel de tous mes objets personnalisés doit avoir été défini de manière incorrecte de manière interne dans Xcode 6 beta 4. Mais l'inspecteur n'en avait aucune indication visuelle.
Notez que si appuyer sur entrer dans la zone de texte Module ne fonctionne pas, essayez de sélectionner la flèche à droite, sélectionnez manuellement votre module actuel, puis effacez la zone de texte et appuyez sur entrée. Vous pouvez également essayer d'appuyer sur Entrée dans la zone de texte de la classe (bien qu'il s'agisse généralement de résoudre un problème différent).
Voici une image pour rendre les choses plus claires:
Parfois, Xcode a manquécustomModule="AppName" customModuleProvider="target"
Pour résoudre ce problème, ouvrez le storyboard en tant que code source et remplacez cette ligne:
<viewController storyboardIdentifier="StoryboardId" id="SomeID" customClass="CustomClass"
sceneMemberID="viewController">
pour ça:
<viewController storyboardIdentifier="StoryboardId" id="SomeID" customClass="CustomClass"
customModule="AppName" customModuleProvider="target" sceneMemberID="viewController">
J'ai eu ce problème après avoir renommé une classe Swift. Résolu en utilisant la directive @objc:
@objc(ForumTopicListViewController) class ForumTopicListViewController
Cela a fonctionné pour moi ..
Vérifiez votre source compilée, que ce fichier (par exemple, ViewController.m) soit ajouté ou non. Dans mon cas, le fichier ViewController n’a pas été ajouté, ce qui me donnait l’erreur.
Cela peut arriver dans n'importe quel Xcode supérieur à 6.0. Cela m'est arrivé après avoir renommé certaines classes ViewController dans le projet Swift (mais je suppose que cela se produira également avec Obj-C). Il vous suffit d'ouvrir le générateur d'interface, d'accéder à l'inspecteur d'identité de ViewController dont la classe a été renommée, de sélectionner la classe et d'appuyer sur Entrée. Cela réaffectera la classe renommée à ViewController sélectionné et réinitialisera également la valeur du module qui sera perdue après avoir renommé la classe.
Mise à jour pour Xcode 8.1 (probablement aussi 8.0):
Xcode 8.1 vient de planter. Simplement et ennuyeux, ça plante et n'imprime rien. Je poursuivais ce crash fantôme pendant une heure pour découvrir que c'était exactement la même chose: une classe non assignée dans IB. Si vous rencontrez des plantages fantômes, vérifiez d'abord dans IB que les classes non attribuées sont les premières.
Parfois, le contrôleur que vous fournissez perd son adhésion cible de l'application en cours. Dans ce cas, appuyer sur Entrée dans le champ "Module" ne fera rien. Accédez au contrôleur et assurez-vous que l'appartenance à la cible est définie sur l'application actuelle.
Je l'ai corrigé en faisant exactement le contraire de ce que ChikabuZ avait suggéré (merci de l'avoir signalé, cependant). Dans le fichier de scénario, trouvez ceci:
<viewController storyboardIdentifier="StoryboardId" id="SomeID" customClass="CustomClass" customModule="AppName" customModuleProvider="target" sceneMemberID="viewController">
et le remplacer par ceci:
<viewController storyboardIdentifier="StoryboardId" id="SomeID" customClass="CustomClass" sceneMemberID="viewController">
Je n'arrive pas à croire combien d'heures je perds à résoudre des bugs dans le compilateur Swift et Xcode 6
J'ai fait face à ce problème dans Xcode 8 , pour le résoudre, j'ai dû modifier le storyboard dans l'éditeur de texte.
En général, recherchez votre contrôle et supprimez customModule
et customModuleProvider
de l'entité de contrôle.
A fait un tour pour moi.
Vérifiez si votre classe a le droit Adhésion cible .
J'ai rencontré ce problème dans Xcode 6.1 lorsque j'ai supprimé Main.storyboard
, le fichier LaunchScreen.xib
et les classes ViewController
par défaut de mon projet.
Je l'ai corrigé en supprimant les entrées Launch Screen File
et Main Interface
de Info.plist
J'ai googlé partout pour cela. Aucune des réponses ne fonctionne pour moi avant que je rencontre un mec qui m'a demandé de déplacer mon dossier de projet sur le bureau. Cela a juste fonctionné automatiquement. Apparemment, si vous avez votre dossier de projet trop en profondeur, XCODE se brise réellement.
J'ai résolu ce problème en ouvrant mon fichier de storyboard en tant que code source et en utilisant la commande-F pour rechercher ma classe inconnue et supprimer la classe personnalisée qui lui était associée.
Ces étapes fonctionnent pour moi.
1) Effacer les données dérivées.
2) Supprimer les fichiers .h et .m
3) Créez à nouveau des fichiers .h et .m
Ma solution (Xcode 8.1 Swift 3.0):
Classe inconnuexxxdans le fichier Interface Builder.
Ouvrez StoryBoard en tant que code source et recherchezxxx. Supprimer l'attribut qui contient la valeurxxx. Construire et exécuter.
J'ai résolu ce problème en tapant le nom du module (malheureusement, la liste déroulante ne montrera rien ...) dans la classe personnalisée de l'inspecteur d'identité pour tout le contrôleur de vue et les vues.
Vous devrez peut-être également indiquer le fournisseur cible. Pour atteindre cet objectif, vous pouvez ouvrir le scénario en mode code source et ajouter l'attribut "customModuleProvider" dans les accolades ViewController et View.
Ce que @gfrs a dit est correct, vous devez configurer le module. Cependant, j’ai déjà eu un problème avec le fait que ma classe ne figurait pas dans la liste déroulante Class
. Finalement, j'ai supprimé le fichier Swift, redémarré Xcode et recréé le fichier. Enfin, la classe était répertoriée et pouvait être utilisée dans Storyboard.
Regardez aussi cette réponse , qui semble résoudre le «vrai» problème que j'ai rencontré.
Dans mon cas, class référencé dans Storyboard/xib n'avait pas Target Membership défini.
Pour résoudre ce problème, attribuez aux fichiers .h
et .m
de cette classe la même appartenance à la cible que vos autres classes.
J'ai fait face au problème lorsque j'ai porté le storyboard d'un projet Swift dans un projet Objective-c, remarquant la réponse de vvkuznetsov , les deux projets utilisant le même identifiant. I "Produit -> Nettoyer" et appuyez sur la touche Entrée dans le champ de texte Module et Classe. le problème a disparu.
J'ai corrigé cela dans le sens de ce que Laura avait suggéré, mais je n'avais pas besoin de recréer les fichiers.
A l'aide de XCode 4, dans le navigateur de projet, sélectionnez le fichier .m contenant la classe dont il se plaint.
Allez dans Affichage-> Utilitaires-> Afficher l'inspecteur de fichier .__ (cela affichera l'inspecteur de fichier à droite avec les informations du fichier .m)
Ouvrez la section Adhésion cible et assurez-vous que votre cible est sélectionnée pour ce fichier .m
Lorsque j'ai ajouté mon fichier .m à mon projet, il ne l'a pas ajouté à ma cible par défaut pour une raison quelconque, ce qui m'a amené à obtenir l'erreur mentionnée.
Ma solution était de supprimer @objc de la définition de classe personnalisée.
Mon problème était une erreur d'utilisateur. J'avais un UIView générique dans mon scénario et dans la section Classe personnalisée de l'Inspecteur de l'identité, j'avais accidentellement changé le nom d'UIView en charabia.
Tout ce qu’il a fallu réparer, c’était de revenir à UIView.
La solution était différente pour moi. Vous devez ajouter le fichier .m de la classe aux sources compilées de la phase de construction de la cible.
J'espère que cela t'aides!
J'ai eu ce problème après avoir ajouté une nouvelle cible, puis créé une nouvelle classe à l'aide de la boîte de dialogue 'Nouveau fichier', mais échoué par erreur à vérifier la nouvelle cible ainsi que la cible d'origine dans la boîte de dialogue de création. cible d'origine. La solution consistait à supprimer les fichiers source (supprimer uniquement la référence), puis à les rajouter en utilisant "Ajouter des fichiers", en vérifiant cette fois les deux cibles.
Ce qui ne fonctionnait que pour moi, c’est d’ajouter le nom du module au fichier xib ...
Sooo, les fichiers xib ressemblent à ceci:
mymodule.MyViewController.xib (Module being the name of the proyect, usually)
HORRIBLE solution à mon avis, mais c’est soi-disant comment Apple veut que nous le fassions maintenant.
Cette question montre 3 solutions de contournement possibles dans la version bêta 4 ... apparemment, Apple n’a pas été très utile dans cette situation, selon certains, parce qu’ils l’appellent "Travailler comme prévu".
J'ai eu le même problème avec Xcode Version 6.1 (6A1052d). Je pense que le problème apparaît si vous avez renommé votre projet App/Xcode.
Ma solution consistait à ajouter manuellement le nom du module dans le constructeur d'interface.
Sélectionnez votre fichier de classe inconnu, ouvrez l'onglet d'inspecteur de fichier, vérifiez votre nom de cible dans Target Membership
. Voilà.
Swift 3 solution.
Tout cela n'a pas fonctionné.
Module
dans le volet de droite ne fonctionnait PAS.Cela a finalement fonctionné.
Juste créez un nouveau répertoire et créez un nouveau projet à l'intérieur de celui-ci. Ajoutez les fichiers sauf Main.sotryboard.
Maintenant, copiez les contrôleurs de vue du projet précédent et collez-les dans le nouveau Main.storyboard.
Voila! Cela marche.
Mon problème était lié à un framework de podfile (en particulier le "BWWalkthrough"). Aucune des solutions ci-dessus n'a fonctionné pour moi, et peu importe comment j'ai essayé, je ne pouvais pas faire en sorte que le module pointe vers mon application.
Ce qui a finalement fonctionné pour moi a été de supprimer la bibliothèque en tant que podfile et de l’ajouter directement à mon projet en tant que bibliothèque statique. Tout était pour moi après cela. Pas tout à fait sûr de ce qui était "cassé" avec l'implémentation de pod de la classe.
Je suis un utilisateur PyObjC
et j'avais ma sous-classe NSView
dans son propre fichier. Pour moi, ce problème a été résolu par le déplacement de la sous-classe NSView
de son propre fichier dans mon fichier AppController.py
. C'est le fichier qui contient le contrôleur d'application.
J'ai eu le même problème, mais pas la même solution.
Le dossier du projet était un peu corrompu, je devais donc copier le dossier de mon projet dans un autre dossier, par exemple votre bureau, puis ouvrir le projet.
Quand il s’ouvrira, allez dans votre projet de création d’interface et vous verrez qu’il reconnaît votre script. Ensuite, vous cliquez bien sur le nom de votre script et appuyez sur Entrée, vous verrez que l’entrée du module le remplira automatiquement.
Et cela fonctionnera comme un charme! :RÉ
Pour moi, j'utilise Xcode7 + Swift2
Résolu ce problème en vérifiant mon code, j'ai cette ligne dans mon viewController:
self?.navigationController?.pushViewController(vc, animated: true)
Ensuite, j'ai réalisé que navigationController n'était pas connecté à la page de détail. Donc, si vous installez un nouveau ViewController avec un ID personnalisé, mieux vaut le vérifier.
J'ai rencontré un problème lorsque j'ai créé un projet avec le même nom qui existait déjà dans mon répertoire de projets (bien qu'il ait été supprimé il y a quelque temps). J'ai écrit ma solution ici https://stackoverflow.com/a/27763697/1654692
Cela a fonctionné pour moi quand rien sinon a fait. Depuis le répertoire du projet dans le terminal:
[~/Developer/MyProject] grep -rn ViewController * | grep -i xib
Ouvrez les fichiers correspondants en tant que code source dans Xcode et modifiez toutes les instances de ViewController selon vos besoins. Dans mon cas, le fichier que je devais ouvrir en tant que source était Main.storyboard et j'ai changé les instances de ViewController en DetailViewController.
J'ai supprimé deux fichiers de Xcode et de main.storyboard, ce qui, selon moi, a été à l'origine de ce problème.
Cela m'est arrivé parce que ma classe était marquée avec @objc
et qu'elle ne pouvait pas trouver le module dans le storyboard. Supprimer @objc
corrige le problème
J'ai eu le même problème avec Xcode 6.3 lorsque j'ai ajouté des fichiers à "myapp" ..__ C'est parce que j'ai choisi "créer une référence de dossier" au lieu de "créer des groupes". option.Et le problème corrigé.
C'est vraiment bizarre quand XCode 10
s'est arrêté pour "raffiner le débogage".
Dans mon cas, j’ai paramétré UITableViewDelegate et UITableViewDataSource avec Storyboard et j’ai oublié d’implémenter les méthodes requises.
Je voulais juste d'abord tester la vue, avant d'implémenter ces méthodes, puis planter! XCode 9
, mettra en garde sur ces méthodes, mais XCode 10
, a vraiment rendu mon code lent, pas sur celui-ci, les autres personnes ayant traversé ce "doute d'erreur".
J'espère que cela aidera quelqu'un.
Merci
dans mon cas, j'ai configuré l'application en tant qu'application universelle, donc xcode crée deux storyboards. Mais je n'utilisais que (conçu) uniquement des storyboards pour iPhone. et essayer d'exécuter une application sur iPad.pour résoudre le problème, il suffit de créer une application comme pour iPhone et fonctionne parfaitement.
Pour moi, le problème était que je faisais référence à une classe personnalisée dans le storyboard (qui correspond à un fichier .h), mais je n'avais pas de commande @implementation dans le fichier .m.
Cela m'est arrivé parce que mon projet s'appelait "ä, ü, ö"
N'utilisez pas d'espaces dans le nom du projet, sinon la classe personnalisée ne trouvera pas vos propres classes.
Je jouais avec la classe de printemps. Et cette erreur m'est arrivée parce que j'ai utilisé le dossier comme référence lors du déplacement de toute la classe du dossier dans le projet au lieu de créer des groupes. Donc c'était ma solution, n'utilisez pas le dossier comme référence mais créez des groupes.
J'ai rencontré un tel problème sur Xcode 6 lorsque j'ai supprimé les fichiers ViewController.h et ViewController.m déjà inclus de mon nouveau projet basé sur une vue, et supprimé la scène liée à cette classe du storyboard. Ainsi, si vous essayez d’accéder à Fenêtre -> Projets -> votre_projet et supprimez les données dérivées, tout ira bien.
Dans mon cas, le problème était dû au fait que notre scénario principal soit défini comme écran de lancement et que je reçois une erreur de console (pas de blocage) au démarrage de l'application pour chaque contrôleur de vue personnalisé référencé dans le scénario.
Nous avions couvert XIBs et lancé des images sur des story-boards et je n'avais pas encore réussi à faire fonctionner l'écran de lancement à nouveau. Quand j'ai enfin eu le temps de créer un story-board de base, sans aucun contrôleur de vue personnalisé (ce qui n'est pas autorisé), ces erreurs de console ont cessé d'apparaître.
Dans certains cas, le ViewController.h/m où dans une lib. Les projets sont toujours générés, mais depuis Xcode 6.3, l'erreur ci-dessus a été affichée au moment de l'exécution. Remettre les deux fichiers dans le projet a résolu le problème.