关于Block代码块的使用方法

一、概念

首先需要了解的是Block是一个代码块,是一个变量的形式存在的。

二、构成了解

我们需要在函数中声明block,因为是变量的形式,而且存在静态变量形式


类型1:

 NSString* (^blocks)(NSString*)= ^(NSString *str)

    {

        //NSLog(@"this is :%@",str);

        return str;

    };


返回值类型是字符串,如同函数一样,返回值类型写在最前面

^blocks是声明一个代码块,名字叫做blocks

后面括号跟的是参数的类型,如果没有参数返回void,如果有多个参数类型,那么逗号分隔列出

等于号后面的是参数名列表。

因为写的是一个有返回值的block,所以需要return一个与返回值类型相同类型的值,这里返回的是参数字符串


类型2:

int (^david)(int)= ^(int num)

    {

        return num*5;

    };


这里的返回值类型是一个int,代码块名字叫做david,参数是一个int类型的变量

等于号后面是参数列表,执行的语句是return num *5这句话。


因为如上的两个例子都是有返回值的类型,那么我在调用的时候可以直接使用。

例如:


    NSLog(@"this is block:%@",blocks(@"hello"));

    NSLog(@"this is block:%d",blocks(5));



类型3:

void (^david)(void)= ^(void)

    {

            NSLog(@"I am a block code!");

    };


这里只是简单的执行了一句话,调用方法就是直接打印或者当作变量直接使用。


  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 React 中,可以使用第三方库 React Markdown,它可以将 Markdown 格式的文本转换成 HTML 格式,并且支持代码块的渲染。 首先,需要安装 React Markdown: ```bash npm install react-markdown ``` 然后,可以在组件中引入 React Markdown,例如: ```jsx import ReactMarkdown from 'react-markdown'; function MyComponent() { const markdownText = ` # Hello, world! Here is a code block: \`\`\`javascript const greeting = "Hello, world!"; console.log(greeting); \`\`\` `; return ( <div> <ReactMarkdown source={markdownText} /> </div> ); } ``` 在上面的例子中,我们将 Markdown 格式的文本作为 `source` 属性传递给 `ReactMarkdown` 组件,并且在文本中使用三个反引号来标记代码块。React Markdown 会自动识别代码块,并将其渲染成 `<pre>` 和 `<code>` 标签。 你还可以通过 `renderers` 属性来自定义代码块的渲染方式,例如: ```jsx import ReactMarkdown from 'react-markdown'; function MyComponent() { const markdownText = ` # Hello, world! Here is a code block: \`\`\`javascript const greeting = "Hello, world!"; console.log(greeting); \`\`\` `; const CodeBlock = ({ language, value }) => { return ( <pre> <code className={`language-${language}`}>{value}</code> </pre> ); }; return ( <div> <ReactMarkdown source={markdownText} renderers={{ code: CodeBlock }} /> </div> ); } ``` 在上面的例子中,我们定义了一个名为 `CodeBlock` 的组件来自定义代码块的渲染方式,并将其作为 `renderers` 属性的值传递给 `ReactMarkdown` 组件。在 `CodeBlock` 组件中,我们使用 `prismjs` 库来高亮代码块,并且根据代码块的语言来添加对应的类名。 希望这能帮助到你。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值