Cakephp中使用JavaScriptHelper来引入js文件
页面的head部分的内容在Cakephp中主要是有htmlhelper来进行控制的,而js部分则是由JavaScripthelper来进行控制的,在controller里面设置好:var $helpers = array(’Html’,'Javascript’);就可以在ctp文件中使用JavaScripthelper对象:$javascript了。具体见正文。
前提是js文件都放在了 webroot/js 目录下面了,下面是范例。
1、$javascript->link($JsName,0); echo $script_for_layout;
在 views/controllers/方法名.ctp文件里面,用$javascript->link($JsName,0);来把 webroot/js/jsname.js 文件加载到 views/layouts/default.ctp 的 $script_for_layout 里面去。
2、echo $javascript->link($JsName,1);
这句话是直接在views/layouts/default.ctp里面用的,放在head区就可以了,或者放置在 views/controllers/方法名.ctp文件 里面也是可以的。
3、echo $javascript->includeScript();
这条语句很牛X,直接把所有的 webroot/js/ 所有js文件 全部读取出来,并打印出来。和php的include函数是一样的感觉,别的语句是生成 <script src=””></script>,这个生成的是<script>js1的内容,js2的内容….< /script>,放在layout的head区域很合适。
4、echo $javascript->includeScript($JsName);
这个是上边语句很类似,只是把某个特定的js文件的内容打印出来而已。
让我们来理解 Blog 例子中的代码(不使用 $scaffold)
- 按照命名约定, 数据库表 posts 对应有 Post 模型类, 定义在 app/models/post.php 中
- 在 app/controllers/posts_controller.php 中建立控制类 PostsController 使用 Post 模型类
- 控制类 PostsController 中如果定义 index 动作, 其输出在 app/views/posts/index.thtml 中定义
- 目录结构
app
于是, 请求 http://.../posts/index 使用 app/controllers/ 中(注意此两目录名不出现在请求路径里)控制类 PostsController 的动作 index 来处理, 用 app/views/posts/index.thtml 响应返回显示
- models
- post.php
- controllers
- posts_controller.php
- views
- posts
- index.thtml
- view.thtml
- edit.thtml
- add.thtml
- ...
- layouts
- default.thtml
- posts
- models
- 在动作 index 结束时会自动调用 render 方法用默认的布局 default.thtml 显示 index.thtml 视图
- 而布局 default.thtml 除了定义页头页尾等, 其中的 echo $content_for_layout 是实际显示 index.thtml 的地方
- 在 app/views/layouts/default.thtml 中可以自定义布局以代替默认的布局
- 动作 index 中的关键代码 $this->set('posts', $this->Post->findAll());这样, 视图 index.thtml 中的数组型变量 $posts 通过模型类 Post 拿到了数据库表 posts 的所有记录
- 是设定 index.thtml 视图中的变量其名为 posts 的值
- 而其中 $this->Post 按照命名约定是 Post 模型类
- 同样, 请求 http://.../posts/view/3 会找到控制类 PostsController 的动作 view 来处理, 用 app/views/posts/view.thtml 响应返回显示, 不过还带有动作参数 $id 值为 3
- 动作 view 中的代码 $this->set('posts', $this->Post->read(null, $id)); 设定 view.thtml 视图中的变量 $posts
- 视图 view.thtml 中的代码如 echo $posts['Post']['title'] 显示表 posts 中记录的 id 为 3 的字段 title 的值(温馨提醒中间 Post 是大写的 P)
- 动作 edit 和 add 都要用到代码 $this->Post->save($this->data) 通过模型类 Post 保存控制类的参量 $this->params 所拥有的数据
- $this->data 是 $this->params['data'] 的别名, 指表单(form) 通过提交方式 POST 上来的数据
.:: $html ::.
举例
- 或许超链接更简单了 echo $html->link('超链接文字', '超链接地址')
- 如果当前视图在 app/views/posts/ 目录中, '超链接地址'是这个当前视图目录的相对地址
- 插入图片不难 echo $html->image('图片地址', array('alt'=>"", 'border'=>"0"))用图片作为超链接稍复杂点, 详细方法参数说明请查 Cake 手册 echo $html->link($html->image('图片地址'), '超链接地址', null, null, false)
- 图片放在 app/webroot/img/ 目录中, '图片地址'是这个图片存放目录的相对地址
- 在数组里放图片链接的属性
Cakephp中使用JavaScriptHelper来引入js文件的更多相关文章
- 1.在html中引入js文件和Jquery框架
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Vue在单独引入js文件中使用ElementUI的组件
Vue在单独引入js文件中使用ElementUI的组件 问题场景: 我想在vue中的js文件中使用elementUI中的组件,因为我在main.js中引入了element包和它的css,并挂载到了全局 ...
- vue脚手架使用swiper /引入js文件/引入css文件
1.安装vue-cli 参考地址:https://github.com/vuejs/vue-cli 如果不使用严格语法需要在后三项打no:(加了挺头疼的,老是报错,但是对自己的代码规范性也是有很大的帮 ...
- jsp引入js文件
转自:http://blog.csdn.net/ppzhangj/article/details/7859628 1)引入的js文件出错, 检查方法:将Js的内容写在当前的页面的<script& ...
- vue引入swiper vue使用swiper vue脚手架使用swiper /引入js文件/引入css文件
vue引入swiper vue使用swiper vue脚手架使用swiper /引入js文件/引入css文件 ------------------------------------------- ...
- 使用其他服务器引入JS文件
使用其他服务器引入JS文件,1,减轻服务器压力2,速度快3,可以缓存 cdnjs库,更新比较快https://cdnjs.com/ cdn库 引入JS文件如:jquerybootcdn : https ...
- vue项目 引入js文件
例如我想将laydate.js引到vue项目中 将用到的js文件放到static文件夹内,在项目的根目录下的index.html内引入 <script src="static/js/l ...
- 防止多次引入js文件导致的重复注册点击事件
前端代码中的js文件如果是动态引入的或者是某个事件操作进行注册的,那么重复的引入js文件或者多次触发注册事件会导致事件多次进行注册,造成不必要的麻烦,所以需要在每次注册之前将先前的事件进行取消,下面以 ...
- vue引入js文件时报This dependency was not found:错误
vue引入js文件时报This dependency was not found:错误 使用了很多方法,原来是这么小的问题,特此记录 解决办法 添加 ./
随机推荐
- 基于QT和OpenCV的人脸检測识别系统(2)
紧接着上一篇博客的讲 第二步是识别部分 人脸识别 把上一阶段检測处理得到的人脸图像与数据库中的已知 人脸进行比对,判定人脸相应的人是谁(此处以白色文本显示). 人脸预处理 如今你已经得到一张人脸,你能 ...
- redis主从配置<转>
一.Redis的Replication: 这里首先需要说明的是,在Redis中配置Master-Slave模式真是太简单了.相信在阅读完这篇Blog之后你也可以轻松做到.这里我们还是先列出一些理论性的 ...
- [转] C#开源项目大全
商业协作和项目管理平台-TeamLab 网络视频会议软件-VMukti 驰骋工作流程引擎-ccflow [免费]正则表达式测试工具-Regex-Tester Windows-Phone-7-SDK ...
- Web API(六):使用Autofac实现依赖注入
在这一篇文章将会讲解如何在Web API2中使用Autofac实现依赖注入. 一.创建实体类库 1.创建单独实体类 创建DI.Entity类库,用来存放所有的实体类,新建用户实体类,其结构如下: us ...
- jQuery(四):HTML代码操作
html()可以对HTML代码进行操作,类似于元素JavaScript中的innerHTML. 例如: 示例: <!DOCTYPE html> <html lang="en ...
- git设置HTTP代理
git设置HTTP代理 设置HTTP代理 如果公司使用代理,git就需要设置代理才能克隆远程仓库 执行下面两条语句 git config --global http.proxy 10.167.32.1 ...
- php curl_multi系列函数实现多线程抓取网页
最近几天在做一个多搜索引擎关键字排名查询工具,用于及时方便的了解关键词在各大搜索引擎的排名. 在抓取360搜索的时候,发现360搜索每页只支持显示10个搜索结果,如果想获取100个搜索结果数据,就得搜 ...
- [spark] spark 特性、简介、下载
[简介] 官网:http://spark.apache.org/ 推荐学习博客:http://dblab.xmu.edu.cn/blog/spark/ spark是一个采用Scala语言进行开发,更快 ...
- 关于socket的知识总结
简单点说: 阻塞就是干不完不准回来, 非组赛就是你先干,我现看看有其他事没有,完了告诉我一声 我们拿最常用的send和recv两个函数来说吧... 比如你调用send函数发送一定的Byte,在系 ...
- tomcat部署时war和war exploded区别
war模式—-将WEB工程以包的形式上传到服务器 war exploded模式—-将WEB工程以当前文件夹的位置关系上传到服务器