前言
看到了 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
原文链接:字符串字符分割和驼峰形式的转换