찾다
PHP 프레임워크ThinkPHPthinkPHP가 ajax를 사용하여 이미지를 비동기식으로 업로드하고 표시 및 삭제하는 방법에 대한 자세한 설명

다음 튜토리얼 칼럼인 thinkphp에서는 thinkPHP가 ajax를 사용하여 이미지를 비동기적으로 업로드하고 표시하고 삭제하는 방법을 소개합니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

thinkPHP는 ajax를 사용하여 사진을 비동기적으로 업로드하고 표시하고 삭제합니다

최근 tp5를 학습하는 과정에서 프로젝트에 테마 사진을 선택하는 게시 기능이 있습니다. 다음과 같습니다:

thinkPHP가 ajax를 사용하여 이미지를 비동기식으로 업로드하고 표시 및 삭제하는 방법에 대한 자세한 설명

원본 파일 업로드 처리를 활용합니다. 업로드된 이미지는 원본 js 문을 통해 실시간으로 표시될 수 있지만 이는 많은 호환성 문제를 수반합니다. Ajax 기술을 사용하여 호환성 문제 없이 선택한 사진을 선택적으로 삭제하는 기능을 구현합니다.


양식 파일 형식:


    主题图片:                   图片上传               

Ajax 요청을 보내야 하는 경우 물론 해당 양식은 우리의 요구 사항을 충족할 수 없습니다. 따라서 Ajax 요청을 만들고 선택하는 데 도움이 되도록 클릭 이벤트를 양식과 연결해야 합니다. 영상.
이미지 업로드 버튼을 클릭하면 Ajax 업로드를 구현하기 위한 이미지 선택이 실행됩니다.

JavaScript 코드:

<script></script>
<script>
    function upimg(obj)
    {
        if( obj.value == "" ) {
            return;
        }
        var formdata = new FormData();
        //<input type="file" name="img" value="" />
        formdata.append("img" , $(obj)[0].files[0]);//获取文件法二
        $.ajax({
            type : &#39;post&#39;,
            url : &#39;/home/note/upimg&#39;, //接口
            data : formdata,
            cache : false,
            processData : false, // 不处理发送的数据,因为data值是Formdata对象,不需要对数据做处理
            contentType : false, // 不设置Content-type请求头
            success : function(response){
                console.log(response);
                var html = &#39;<p style="position: relative;margin-right: 20px;margin-bottom: 15px;width: 132px;display: inline-block;border: 1px solid #CCC;background:#EEE;">&#39;
                        +&#39;<span style="display: block;width: 120px;height: 80px;border: 1px solid #F2F1F0;margin: 5px;overflow: hidden;">&#39;
                        +&#39;<img  src="/static/imghwm/default1.png"  data-src="&#39;+response+&#39;"  class="lazy"     style="max-width:90%" / alt="thinkPHP가 ajax를 사용하여 이미지를 비동기식으로 업로드하고 표시 및 삭제하는 방법에 대한 자세한 설명" >&#39;
                        +&#39;&#39;
                        +&#39;<input type="hidden" name="imgs[]" value="&#39;+response+&#39;" />&#39;
                        +&#39;<a onclick="delImg(this);" style="z-index: 10;display: block;top: -8px;cursor:pointer;right: -8px;position:absolute;width: 20px;height: 20px;background: #CCC;border-radius:100%;text-align:center;line-height: 20px;border: 1px solid #C1C1C1;color: #555;">X&#39;
                        +&#39;&#39;;

                $(&#39;#img-list-box&#39;).append(html);
            },
            error : function(){ }
        });
    }

    function delImg(obj)
    {
        $(obj).parent(&#39;p&#39;).remove();
    }
</script>

이미지를 클릭하면 처리를 위해 서버로 전달됩니다.
php 인터페이스 파일:

    public function upimg()
    {
        //验证
        $file = request()->file('img');
        // 移动到框架应用根目录/public/uploads/ 目录下
        if($file){
            $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
            if($info){
                // 成功上传后 获取上传信息
                $img_src = '/uploads/'.$info->getSaveName();
                echo $img_src; //返回ajax请求
            }else{
                // 上传失败获取错误信息
                $this->error($file->getError());
            }
        }
    }

향상된 렌더링:

thinkPHP가 ajax를 사용하여 이미지를 비동기식으로 업로드하고 표시 및 삭제하는 방법에 대한 자세한 설명

위 내용은 thinkPHP가 ajax를 사용하여 이미지를 비동기식으로 업로드하고 표시 및 삭제하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 segmentfault에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기