php iframe 隐藏 地址,php+iframe实现隐藏无刷新上传文件

首先ajax不能上传文件,这误导了我有段时间,今晚睡不着就照着说明做了个无刷新上传文件

其实原理很简单

和一般的

标签相比多了一个target属性罢了,用于指定标签页在哪里打开以及提交数据。

如果没有设置该属性,就会像平常一样在本页重定向打开action中的url。

而如果设置为iframe的name值,即"upload"的话,就会在该iframe内打开,因为CSS设置为隐藏,因而不会有任何动静。若将display:none去掉,还会看到服务器的返回信息。

另外贴一下自己组织的类。

class upload

{

public $_file;

public function __construct( $name =null)

{

if(is_null($name) || !isset($_FILES[$name]))

$name = key($_FILES);

if(!isset($_FILES[$name]))

throw new Exception("并没有文件上传");

$this->_file = $_FILES[$name];

if(!is_uploaded_file($this->_file['tmp_name']))

throw new Exception("异常情况");

if($this->_file['error'] !== 0)

throw new Exception("错误代码:".$this->_file['error']);

}

public function moveTo( $new_dir)

{

$real_dir = $this->checkDir($new_dir);

return move_uploaded_file($this->_file['tmp_name'], $real_dir.'/'.$this->_file['name']);

}

private function checkDir($dir)

{

$real_dir = realpath($dir);

if($real_dir === false)

throw new Exception("给定目录{$dir}不存在");

if(!is_writable($real_dir))

throw new Exception("给定目录{$dir}不可写");

return $real_dir;

}}

调用示例:

$inputName = 'uploadfile';

// 即 中的name值,不填也行

$upload = new upload($inputName);

$new_dir = "/www"; // 将文件移动到的路径

$upload->moveTo($new_dir);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 iframe 实现点击导航无刷新切换页面的基本思路是:将导航链接的目标页面放入 iframe 中,点击导航链接时,只需要切换 iframe 的 src 属性即可实现刷新切换页面。 以下是实现步骤: 1. 在 HTML 文件中添加一个 iframe 元素,设置其 id 和 name 属性为相同的值,以便在后面使用 JavaScript 操作 iframe。 2. 在导航链接中添加 target 属性,将其值设置为 iframe 的 name 属性,以便点击链接时在 iframe 中打开目标页面。 3. 使用 JavaScript 获取导航链接元素,为其添加点击事件监听器,在事件处理函数中获取链接的 href 属性值,将其赋值给 iframe 的 src 属性,即可实现刷新切换页面。 代码示例: HTML 文件中添加 iframe 元素: ```html <iframe id="myFrame" name="myFrame"></iframe> ``` 导航链接添加 target 属性: ```html <a href="page1.html" target="myFrame">Page 1</a> <a href="page2.html" target="myFrame">Page 2</a> <a href="page3.html" target="myFrame">Page 3</a> ``` JavaScript 代码实现: ```javascript const links = document.querySelectorAll('a[target="myFrame"]'); const iframe = document.getElementById('myFrame'); links.forEach(link => { link.addEventListener('click', event => { event.preventDefault(); // 阻止默认行为 const href = event.target.getAttribute('href'); iframe.setAttribute('src', href); }); }); ``` 注:使用 iframe 实现页面无刷新切换存在一些问题,比如无法使用浏览器的前进和后退功能,也无法在 iframe 中执行一些 JavaScript 代码。因此,建议使用其他技术实现页面无刷新切换,比如 Ajax 和 History API。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值