前言
看到了 Phalcon 的 Model 用法,想在自己的框架里实现,便稍微研究了一番,原理还是蛮简单的。
Phalcon 提供了三种方法 findBy、findFirstBy、countBy,它使用魔术方法 __callStatic 来解析用户调用的方法。
例如:用户调用 findFirstByUserMobile 方法,Phalcon 会将其分割成 findFirstBy 和 UserMobile。接着会对 UserMobile 进行处理,转换成 user_mobile。这就是这篇文章的由来。
字符分割形式转换驼峰形式
这里主要是运用了 ucwords 的方法。
先将字符串转换为小写,再连接符号统统转换为空格,接着使用 ucwords 将每个单词的首字母改为大写,最后取出空格。
// 这里主要是运用了ucwords的方法
function camelize($string, $separator = '_')
{
// 将字符串转换为小写
$string = strtolower($string);
// 为了能够使用ucwords方法,将连接符号统统转换为空格
$string = str_replace($separator, ' ', $string);
// 将每个单词的首字母改为大写
$string = ucwords($string);
// 去除空格
return str_replace(' ', '', $string);
}
echo camelize('terse_test'); // TerseTest
复制代码
驼峰形式转换字符分割形式
这个方法比较巧妙,当初看见的时候,还赞叹了一番。
主要原理是在小写字母和大写字母之间加上连接符号,然后转换为小写。
// 这个方法比较巧妙,当初看见的时候,还赞叹了一番
function uncamelize($string, $separator = '_')
{
// 在小写字母和大写字母之间加上连接符号
$string = preg_replace('/([a-z])([A-Z])/', "$1" . $separator . "$2", $string);
// 转换为小写
return strtolower($string);
}
echo camelize('TerseTest'); // terse_test
复制代码
Laravel 在处理字符串的时候使用的正则是 ~(?<=\w)([A-Z])~ 后期仔细想了想,还是蛮有道理的,毕竟跟大写字母在一起的不一定是小写字母。
总结
刚开始在准备这个方法的时候,思路要比现在复杂多了。多看多思考,果然是有帮助的。
-- EOF --
本文转载自IMJCW
原文链接:字符串字符分割和驼峰形式的转换
最后
以上就是鲜艳老虎最近收集整理的关于字符串字符分割和驼峰形式的转换的全部内容,更多相关字符串字符分割和驼峰形式内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复