iOS个人整理22-可视化编辑-XIB

2024-05-11 21:32

本文主要是介绍iOS个人整理22-可视化编辑-XIB,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、可视化编辑-XIB

做UI的自然要有可视化编程,有拖拽控件的便利方法,现在开始学习xib的可视化编辑

基础概念

GUI:图形用户界面 (Graphical User Interface),也就是图形显示计算机操作用户界面

Interface Builder(简称IB):是Max OS X平台下用于设计和测试图形用户界面(GUI)的应用程序,代码和IB都可以生成GUI

IB可以使开发者简单快捷地开发出符合Mac西路操作系统的GUI。通常你只需要进行简单的拖拽来构建GUI

IB使用Nib文件来存储GUI资源,在需要时,Nib文件可以被快速地载入内存。


iOS下可视化编程分为两种方式:xib和storyBoard

在使用xib和storyBoard创建GUI时,以XML文件格式存储在Xcode中,编译时生成Nib的二进制文件。运行时,Nib文件被加载并创建GUI元素


xib的创建和使用

1.在新建UIKIT框架下的类时,勾选Also create XIB file选项,就会创建出和一个类关联的xib文件

 


2.如果忘记勾选Also create XIB file,可以在单独创建一个XIB文件,然后再手动将其和对应的类关联起来

这个过程比较麻烦,还不如删了重新建


(1)先创建一个在User Interface中的empty文件,命名随意,最好和类相关



(2)然后给empty文件拖拽添加一个View控件



(3)然后在empty文件的file's owner的Custom Class的Class那栏填上要关联的类的名字



(4)最后把file's owner的OutLets下的View的关联拖到控件View上



真是麻烦


创建完成之后是初始化,xib创建的视图控制器的初始化方式有所不同

TestXibViewController *testXibVC = [[TestXibViewController alloc]initWithNibName:@"TestXibViewController" bundle:nil];

NibName:当前控制器相关联的Nib文件,如果写nil,默认为同名文件

NibBundle:当前应用程序所在的文件,nil默认为mainBundle。

然后就可以在xib的选项卡里面干各种事情了



二、控件的拖拽和关联

虽然可视化方便了不少,但很多问题还需要代码来解决

1.我们拖拽一个UILabel到View上,它和代码没有任何关联

我吗需要点击右上角两个圈圈的按钮,他可以双屏显示,同时看到Xib和相关类的代码

用鼠标右键按住控件Label,拖拽到.h文件的属性声明处

出现小框,这里可以设置此Label的名字,设置为xibLabel


命名完毕点击connect得到了这个Label属性的声明

然后就可以在代码中对这个Label进行各种设置,而不再需要对Label进行初始化的操作。


2.同理如果是一个Button,可以给给他命名,并且添加方法,在Connection选项中选OutLet就是声明属性,选Action就是声明方法

声明方法后,会自动在.m文件中添加一个空的方法

  



3.再说一下代理设置

拖拽一个UITextField到View上,鼠标右键按住UITextField拖向File's Owner的正方体,

弹出一个小选框,选delegate,点击就讲这个UITextField的代理设置为当前的视图控制器了






4.再补充一点

如果拖进tableView控件,一定要记得给控件拖拽代理dataSource和delegete到所在的ViewController上


如果在xib的面板上自己添加自定义的tableViewCell

在注册单元格时有所不同,要先创建nib

//XIB中注册单元格UINib *cellNib = [UINib nibWithNibName:@"CustomTableViewCell" bundle:nil];//注册[_myXibTableView registerNib:cellNib forCellReuseIdentifier:@"CELL"];
如果使用tableview自带的cell,就用通用方法注册即可

[_myTableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"CELL"];


这篇关于iOS个人整理22-可视化编辑-XIB的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/980709

相关文章

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

使用Folium在Python中进行地图可视化的操作指南

《使用Folium在Python中进行地图可视化的操作指南》在数据分析和可视化领域,地图可视化是一项非常重要的技能,它能够帮助我们更直观地理解和展示地理空间数据,Folium是一个基于Python的地... 目录引言一、Folium简介与安装1. Folium简介2. 安装Folium二、基础使用1. 创建

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM

StarRocks索引详解(最新整理)

《StarRocks索引详解(最新整理)》StarRocks支持多种索引类型,包括主键索引、前缀索引、Bitmap索引和Bloomfilter索引,这些索引类型适用于不同场景,如唯一性约束、减少索引空... 目录1. 主键索引(Primary Key Index)2. 前缀索引(Prefix Index /

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用