thinkphp的m方法怎么用

thinkphp中,M()方法用于实例化一个基础模型类,实例化后只能调用基础模型类(默认是Model类)中的方法,语法“M(‘[基础模型名:]模型名’,’数据表前缀’,’数据库连接信息’)”。

thinkphp的m方法怎么用

本教程操作环境:Windows7系统、thinkphp v5.1版、Dell G3电脑。

M方法用于实例化一个基础模型类,和D方法的区别在于:

不需要自定义模型类,减少IO加载,性能较好;

实例化后只能调用基础模型类(默认是Model类)中的方法;

立即学习“PHP免费学习笔记(深入)”;

可以在实例化的时候指定表前缀、数据库和数据库的连接信息;

D方法的强大则体现在你封装的自定义模型类有多强,不过随着新版ThinkPHP框架的基础模型类的功能越来越强大,M方法也比D方法越来越实用了。

M方法的调用格式:

M('[基础模型名:]模型名','数据表前缀','数据库连接信息')

我们来看下M方法具体有哪些用法:

1、实例化基础模型(Model) 类

在没有定义任何模型的时候,我们可以使用下面的方法实例化一个模型类来进行操作:

//实例化User模型$User = M('User'); //执行其他的数据操作$User->select();

这种方法最简单高效,因为不需要定义任何的模型类,所以支持跨项目调用。缺点也是因为没有自定义的模型类,因此无法写入相关的业务逻辑,只能完成基本的CURD操作。

$User = M('User');

其实等效于:

$User = new Model('User');

表示操作think_user表。M方法和D方法一样也有单例功能,多次调用并不会重复实例化。M方法的模型名参数在转换成数据表的时候会自动转换成小写,也就是说ThinkPHP的数据表命名规范是全小写的格式。

2、实例化其他公共模型类

第一种方式实例化因为没有模型类的定义,因此很难封装一些额外的逻辑方法,不过大多数情况下,也许只是需要扩展一些通用的逻辑,那么就可以尝试下面一种方法。

$User = M('CommonModel:User');

改用法其实等效于:

法语写作助手 法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

法语写作助手 31 查看详情 法语写作助手

$User = new CommonModel('User');

因为系统的模型类都能够自动加载,因此我们不需要在实例化之前手动进行类库导入操作。模型类CommonModel必须继承Model。我们可以在CommonModel类里面定义一些通用的逻辑方法,就可以省去为每个数据表定义具体的模型类,如果你的项目已经有超过100个数据表了,而大多数情况都是一些基本的CURD操作的话,只是个别模型有一些复杂的业务逻辑需要封装,那么第一种方式和第二种方式的结合是一个不错的选择。

3、传入表前缀、数据库和其他信息

M方法有三个参数,第一个参数是模型名称(可以包括基础模型类和数据库),第二个参数用于设置数据表的前缀(留空则取当前项目配置的表前缀),第三个参数用于设置当前使用的数据库连接信息(留空则取当前项目配置的数据库连接信息),例如:

$User = M('db2.User','think_');

表示实例化Model模型类,并操作db2数据库中的think_user表。

如果第二个参数留空或者不传,表示使用当前项目配置中的数据表前缀,如果操作的数据表没有表前缀,那么可以使用:

$User = M('db1.User',null);

表示实例化Model模型类,并操作db1数据库中的user表。

如果你操作的数据库需要不同的用户账号,可以传入数据库的连接信息,例如:

$User = M('User','think_','mysql://user_a:1234@localhost:3306/thinkphp');

表示基础模型类用Model,然后对think_user表进行操作,用user_a账号进行数据库连接,操作数据库是thinkphp。

第三个连接信息参数可以使用DSN配置或者数组配置,甚至可以支持配置参数。

例如,在项目配置文件中配置了:

'DB_CONFIG'=>'mysql://user_a:1234@localhost:3306/thinkphp';

则可以使用:

$User = M('User','think_','DB_CONFIG');

基础模型类和数据库可以一起使用,例如:

$User = M('CommonModel:db2.User','think_');

如果要实例化分层模型的话,利用公共模型类的方式,我们可以使用:

M('UserLogic:User');

来实例化UserLogic,虽然这样做的意义不大,因为可以用

D('User','Logic');

实现同样的功能。

【相关教程推荐:thinkphp框架】

以上就是thinkphp的m方法怎么用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/480460.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 11:09:20
下一篇 2025年11月8日 11:17:52

相关推荐

  • mac html5 怎么下载_mac浏览器直接打开html5文件无需额外下载【说明】

    Mac上HTML5文件被下载而非渲染,需检查文件关联、浏览器安全限制、使用Python服务器托管、验证编码与MIME声明、禁用干扰扩展。 如果您在 Mac 上使用浏览器打开 HTML5 文件时发现需要额外下载而非直接渲染,可能是由于文件关联设置、浏览器默认行为或文件路径问题导致。以下是解决此问题的步…

    2025年12月23日
    200
  • 编程html怎么运行_编程后运行html代码步骤【指南】

    首先保存HTML文件到本地,然后双击用浏览器打开即可查看效果;若需实时预览,可在VS Code中使用Live Server插件;对于需要服务器环境的功能,可通过npx http-server启动本地服务,在浏览器访问localhost地址查看。 如果您编写了一段HTML代码,但不知道如何在浏览器中查…

    2025年12月23日
    000
  • html如何查看_查看HTML源代码与页面结构【结构】

    要查看网页原始HTML源代码或实时DOM结构,可采用五种方法:一、浏览器“查看网页源代码”获取初始HTML;二、开发者工具“元素”面板检查动态DOM;三、地址栏执行javascript指令提取源码;四、用扩展导出结构化HTML快照;五、命令行curl抓取原始响应。 如果您希望了解网页的原始代码构成或…

    2025年12月23日
    000
  • html如何预览_在浏览器中预览HTML页面效果【效果】

    HTML文件预览有五种方法:一、双击用默认浏览器打开;二、右键选指定浏览器打开;三、拖拽文件至浏览器窗口;四、地址栏输入file://路径;五、VS Code用Live Server插件启本地服务器。 如果您编写了一个HTML文件,但不确定其在浏览器中的实际显示效果,则需要通过浏览器进行预览。以下是…

    2025年12月23日
    200
  • HTML如何查看页面性能_开发者工具监控技巧【指南】

    需用Chrome开发者工具的Performance面板录制并分析页面性能数据,包括FPS、长任务、FCP/LCP等指标,再通过Lighthouse审计和Paint Flashing等可视化功能定位瓶颈。 如果您希望评估网页在浏览器中的运行效率,需要借助开发者工具中的性能监控功能来捕获并分析页面加载、…

    2025年12月23日
    200
  • 如何去除html_去除HTML标签提取纯文本内容【提取】

    提取HTML字符串纯文本有五种方法:一、正则表达式去除标签;二、浏览器DOM解析器(textContent);三、Python html模块+正则或BeautifulSoup;四、Node.js jsdom模拟DOM;五、命令行工具如pup批量处理。 如果您需要从一段包含HTML标签的字符串中提取出…

    2025年12月23日
    200
  • 如何查找网站的html_查看网站页面HTML源代码方法【源代码】

    可通过五种方法查看网页HTML源代码:一、快捷键(Win/Linux用Ctrl+U,macOS用Cmd+Opt+U);二、开发者工具Elements面板;三、地址栏输入view-source:前缀;四、安装语法高亮扩展;五、命令行用curl获取。 如果您希望查看某个网站页面的HTML源代码,以便分析…

    2025年12月23日
    000
  • 电脑页面如何调html_在电脑上调试HTML页面的技巧【调试】

    调试HTML页面需五步:一用开发者工具检查元素;二用W3C验证语法;三查资源路径与加载状态;四通过控制台排查JS错误;五跨浏览器对比渲染并处理兼容性问题。 如果您在电脑上编写了HTML页面,但页面显示效果与预期不符,则可能是由于代码语法错误、路径问题或浏览器渲染差异导致。以下是调试HTML页面的常用…

    2025年12月23日
    000
  • 怎么运行.html.tpl_运行.html.tpl文件步骤【指南】

    .html.tpl文件需通过后端模板引擎解析,不能直接运行;首先搭建PHP环境,安装Smarty等模板引擎,配置模板与编译目录,编写PHP脚本加载.tpl文件并分配数据,最后通过访问PHP文件触发渲染,浏览器查看最终HTML。 运行 `.html.tpl` 文件并不是直接像普通 HTML 文件那样在…

    2025年12月23日
    000
  • html怎么本地运行_本地运行html方法【教程】

    双击HTML文件即可用浏览器本地运行,推荐VS Code配合Live Server插件解决资源加载限制,或使用Python/Node快速启服务。 直接双击HTML文件就能本地运行,不需要服务器或额外软件,这是最简单的方式。 用浏览器直接打开HTML文件 这是最常用、最快速的本地运行方法。把写好的.h…

    2025年12月23日
    000
  • php怎么在html5中运行_php在html5中运行方法【教程】

    PHP在服务器端运行,通过嵌入HTML5文件生成动态内容。1. PHP与HTML5协同工作:PHP代码嵌入.html或.php文件,由服务器解析后输出纯HTML至浏览器。2. 创建index.php文件,使用标准HTML5结构,在其中插入等PHP代码,实现动态内容展示。3. 搭建本地环境可选用XAM…

    2025年12月23日 好文分享
    000
  • html怎么用浏览器运行php_浏览器运html中php文件方法【教程】

    正确答案是搭建本地开发环境。需安装XAMPP等集成工具,将.php文件放入htdocs目录,通过http://localhost访问,确保服务器解析PHP并返回HTML给浏览器显示。 PHP 是服务器端语言,不能直接通过浏览器像 HTML 那样双击打开运行。你看到的“在浏览器中运行 PHP”其实是指…

    2025年12月23日
    000
  • Mac Bracket插件魔改,HTML id选择器CSS排序!

    可通过魔改Bracket插件实现HTML中id选择器的CSS规则排序:一、修改插件配置文件,编辑Beautify或CSSPrettify的main.js等文件,在解析逻辑中添加对#开头的选择器优先级判断;二、使用正则表达式预处理,通过(#w+1{2})匹配id规则块,提取后排序并重写回CSS;三、集…

    2025年12月23日
    000
  • Mac Launchpad快捷,HTML+CSS项目一键启动!

    可通过Automator创建应用程序并添加至Launchpad实现一键启动HTML+CSS项目。首先使用Automator选择“应用程序”类型,添加“运行AppleScript”操作,输入打开指定HTML文件的脚本,如tell application “Safari” to …

    2025年12月23日
    000
  • 从IE11迁移至Edge:调用.NET程序集的现代策略

    本文旨在指导开发者如何将原先在ie11中通过“标签直接调用.net程序集的功能,迁移至microsoft edge等现代浏览器。由于安全和技术架构的演进,edge不再支持此类直接调用。文章将详细介绍两种主要的替代方案:利用blazor将c#代码运行于webassembly环境,以及通过clicko…

    2025年12月23日
    000
  • stylelint实时暴击,CSS写错HTML立刻红!

    配置stylelint可实现CSS实时错误检测,通过编辑器集成、Webpack插件、Vite插件及自定义HTML错误注入机制,在开发阶段即时捕获并反馈样式问题,防止错误进入生产环境。 如果您在编写CSS时希望实时捕捉错误,并在HTML预览中立即看到反馈,那么通过配置stylelint可以实现“写错即…

    2025年12月23日
    000
  • Mac Bear标签页同时打开HTML源码和CSS样式

    Bear不支持HTML与CSS标签页式编辑,仅能通过代码块编写并导出预览,建议搭配VS Code等专业工具实现双栏实时开发。 在 Mac 版的 Bear 笔记应用中,无法直接以标签页形式同时打开 HTML 源码和 CSS 样式进行编辑。Bear 是一款专注于简洁写作的 Markdown 笔记工具,它…

    2025年12月23日
    000
  • 使用HTML拖放API获取文件/文件夹名称(无需上传)

    本文详细介绍了如何利用html drag and drop api,在不实际上传文件的情况下,获取用户拖放到网页区域的文件或文件夹名称。这对于仅需文件元信息(如名称)而无需传输文件内容的内部业务应用尤其有用,避免了不必要的上传操作,同时提供了交互式用户体验。 引言:无需上传,仅获取文件/文件夹名称的…

    2025年12月23日
    000
  • 如何下载打印html_HTML页面(打印样式/PDF导出)下载打印方法

    使用浏览器打印功能可将HTML页面导出为PDF,通过“打印预览”调整布局、边距并选择“另存为PDF”即可保存;结合@media print的CSS样式能优化输出效果,隐藏非必要元素、设置分页和字体;开发者还可利用html2pdf.js等库实现一键导出。 要将HTML页面以适合打印的格式保存或导出为P…

    2025年12月23日
    000
  • html编辑器如何内存泄漏检测 html编辑器排查前端问题的工具

    首先使用浏览器开发者工具监控内存,通过堆快照对比查找未释放对象;再利用Performance面板记录内存曲线,定位泄漏点;结合任务管理器观察JS内存增长;采用WeakMap/WeakSet避免强引用;最后用Lint工具检测未清理的监听器或观察者,确保资源正确释放。 如果您在使用HTML编辑器开发前端…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信