웹 프론트엔드 JS 튜토리얼 jquery_jquery를 기반으로 하는 크로스 브라우저 표시를 위한 파일 업로드 제어

jquery_jquery를 기반으로 하는 크로스 브라우저 표시를 위한 파일 업로드 제어

May 16, 2016 pm 06:00 PM
file

이전에 입력 유형="파일"의 스타일을 정의하는 방법을 간략하게 소개하는 짧은 기사를 작성했습니다. 일반적인 양식의 경우 업로드 제어가 적습니다. 이 접근 방식은 코드를 줄일 뿐만 아니라 스타일도 아름답게 만듭니다. 사실 파일 제어 스타일을 정의하는 일반적인 아이디어는 동일합니다. "
firefox에서 input type="file"의 크기는 얼마입니까
"

여기서 참을 수가 없네요. 결과는 성공적입니다. 다음 내용은 위의 두 기사에서 인용되었습니다.
Daniel ppk는 여러 양식 제어 중에서 업로드 파일 제어 스타일이 가장 제어하기 어렵다고 말했습니다. 입력 유형="파일" 스타일 지정 문서를 참조하세요. 이 플러그인은 대부분 이 기사를 기반으로 합니다.
먼저 chrome, ie, firefox 세 가지 브라우저에서 input type="file"의 다양한 표현을 살펴보겠습니다.





크롬은 버튼 라벨 조합과 같다는 점이 가장 큰 차이점으로 보입니다.

ff와 ie는 외관상으로 보면 Firefox가 더 표준적입니다. 실제로 Firefox에는 두 가지 잠재적인 문제가 있습니다. jquery_jquery를 기반으로 하는 크로스 브라우저 표시를 위한 파일 업로드 제어1. Firefox의 입력 너비 정의 현재 지원되지 않습니다(그러나 FF는 크기 속성을 지원합니다. 크기 값을 설정하여 업로드 상자의 크기를 제어할 수 있습니다. 이 크기가 얼마나 큰지에 대해서는 Fanhua-입력 유형의 크기는 무엇입니까=" 기사를 참조하세요. Firefox에서 "파일"을 선택하시겠습니까? ).
2. 파일 양식을 제출할 때 Firefox는 파일 이름만 제출하고 경로는 제출하지 않는 반면, IE는 경로 파일 이름을 제출하지만 파일 이름만 표시할 수 있습니다. Firefox에서 파일양식 제출 시 파일명만 제출되고 경로는 제출되지 않습니다(아쉽게도 당분간은 해결방법이 없습니다) jquery_jquery를 기반으로 하는 크로스 브라우저 표시를 위한 파일 업로드 제어
다양한 브라우저에서 파일이 균일하게 표시되도록 하려면 순수 스타일로는 불가능합니다. 더 이상 제어할 수 없으며 js만 스크립트로 사용할 수 있습니다. 3가지 기본 단계가 있습니다. jquery_jquery를 기반으로 하는 크로스 브라우저 표시를 위한 파일 업로드 제어1. 텍스트 상자와 버튼을 사용하여 입력 유형="파일"을 시뮬레이션합니다.

2. input="file"을 투명하게 만들고 위치 지정을 사용하여 텍스트 상자와 버튼을 완전히 덮습니다.
3. input type="file"이 onchanged되면 ​​js를 사용하여 텍스트 상자의 값을 input type="file"의 값으로 설정합니다.

단계를 이해하면 전체 플러그인을 쉽게 작성할 수 있습니다.




코드를 복사하세요


코드는 다음과 같습니다.
(function($) {
$.fn.fileEveryWhere = function(options) {
var defaults = {
WrapWidth: 300,
WrapHeight: 30,
ButtonWidth: 60,
ButtonHeight: 28,
ButtonText: "Browse",
TextHeight: 28,
TextWidth: 240
};
var options = $.extend(defaults, options);
var browser_ver = $.browser.version.substr(0, 1); var displayMode = ($.browser .msie && browser_ver <= "7 ") ? "inline" : "inline-block";
return this.each(function() {
//포함 항목을 생성하고 상대 위치 지정으로 설정
var 래퍼 = $("
")
.css({
"width": options.WrapWidth "px",
"height": options.WrapHeight "px ",
"display": 디스플레이 모드,
"zoom": "1",
"position": "relative",
"overflow": "hidden",
"z- index":"1"
});
//업로드된 파일 이름을 저장할 텍스트 입력 상자 만들기
var text = $('')
.css({
"width": options.TextWidth "px",
"heigth": options.TextHeight "px"
});
//탐색 버튼 생성
var 버튼 = $('')
.val(options.ButtonText)
$(this ).wrap(wrapper).parent().append (텍스트, 버튼);
$(this).css({
"position": "absolute",
"top": "0" ,
"왼쪽": "0",
"z-index": "2",
"height": options.WrapHeight "px",
"width": options.WrapWidth " px",
"cursor": "포인터",
"opacity": "0.0",
"outline":"0",
"filter": "alpha(opacity:0) "
});
if ( $.browser.mozilla) { $(this).attr("size", 1 (options.WrapWidth - 85) / 6.5) }
$(this). 바인딩("변경", function() {
text.val($(this).val());
})
}); jQuery)


사용은 매우 간단합니다.

$("input:file").fileEveryWhere({parameter})



type="file"의 firefox 입력 너비 정의는 현재 지원되지 않지만 FF는 크기 속성을 지원하여 업로드 상자의 크기를 제어할 수 있습니다.
그런데 이 사이즈 값을 어떻게 설정하는지, size="10"이 얼마나 넓은지, 기본값은 무엇인지 기분에 따라 설정할 수는 없나요? 스크립트로 확인해보세요:
코드 복사 코드는 다음과 같습니다.

< ;script type=" text/javascript">
$(function() {
var fileArray = [];
var i = 0;
while (i < 100) {
fileArray.push( i ":
")
i
}
document.write (fileArray.join( ""));
$("input:file").each(function() { $(this).after("" $(this).width() " ") });
});


Firefox에서 이 결과를 얻으세요:
jquery_jquery를 기반으로 하는 크로스 브라우저 표시를 위한 파일 업로드 제어

발견 특정 규칙, 기본값은 208픽셀, size="1"일 때 85픽셀, 각 크기의 너비가 6.5픽셀씩 다르기 때문에 다음과 같이 크기 값을 동적으로 설정할 수 있습니다.
코드 복사 코드는 다음과 같습니다.
if ($.browser.mozilla) { $(this).attr(" size", 1 (options.WrapWidth - 85) / 6.5)
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Hongmeng 네이티브 애플리케이션 무작위 시 Hongmeng 네이티브 애플리케이션 무작위 시 Feb 19, 2024 pm 01:36 PM

오픈 소스에 대해 자세히 알아보려면 다음을 방문하세요. 51CTO Hongmeng 개발자 커뮤니티 https://ost.51cto.com 실행 환경 DAYU200:4.0.10.16SDK: 4.0.10.15IDE: 4.0.600 1. 애플리케이션을 생성하려면 파일을 클릭합니다. >새파일->CreateProgect. 템플릿 선택: [OpenHarmony]EmptyAbility: 프로젝트 이름 shici, 애플리케이션 패키지 이름 com.nut.shici 및 애플리케이션 저장 위치 XXX(한자, 특수 문자, 공백 없음)를 입력합니다. CompileSDK10, 모델: 스테이지. 장치

Java의 File.length() 함수를 사용하여 파일 크기를 가져옵니다. Java의 File.length() 함수를 사용하여 파일 크기를 가져옵니다. Jul 24, 2023 am 08:36 AM

파일 크기를 얻으려면 Java의 File.length() 함수를 사용하십시오. 파일 크기는 파일 작업을 처리할 때 매우 일반적인 요구 사항입니다. Java는 파일 크기를 얻는 매우 편리한 방법, 즉 길이( ) File 클래스의 메서드입니다. 이 기사에서는 이 방법을 사용하여 파일 크기를 가져오는 방법을 소개하고 해당 코드 예제를 제공합니다. 먼저, 크기를 구하려는 파일을 나타내는 File 객체를 만들어야 합니다. File 객체를 생성하는 방법은 다음과 같습니다: Filef

PHP Blob을 파일로 변환하는 방법 PHP Blob을 파일로 변환하는 방법 Mar 16, 2023 am 10:47 AM

PHP Blob을 파일로 변환하는 방법: 1. PHP 샘플 파일을 생성합니다. 2. "function blobToFile(blob) {return new File([blob], 'screenshot.png', { type: 'image/jpeg' })를 통해 } ” 메소드를 사용하여 Blob을 파일로 변환할 수 있습니다.

Java의 File.renameTo() 함수를 사용하여 파일 이름 바꾸기 Java의 File.renameTo() 함수를 사용하여 파일 이름 바꾸기 Jul 25, 2023 pm 03:45 PM

Java의 File.renameTo() 함수를 사용하여 파일 이름을 바꿉니다. Java 프로그래밍에서는 파일 이름을 바꿔야 하는 경우가 많습니다. Java는 파일 작업을 처리하기 위해 File 클래스를 제공하며 renameTo() 함수는 파일 이름을 쉽게 바꿀 수 있습니다. 이 기사에서는 Java의 File.renameTo() 함수를 사용하여 파일 이름을 바꾸는 방법을 소개하고 해당 코드 예제를 제공합니다. File.renameTo() 함수는 File 클래스의 메서드입니다.

Java의 File.getParentFile() 함수를 사용하여 파일의 상위 디렉토리를 가져옵니다. Java의 File.getParentFile() 함수를 사용하여 파일의 상위 디렉토리를 가져옵니다. Jul 27, 2023 am 11:45 AM

Java의 File.getParentFile() 함수를 사용하여 파일의 상위 디렉터리를 가져옵니다. Java 프로그래밍에서는 파일과 폴더를 조작해야 하는 경우가 많습니다. 파일의 상위 디렉토리를 가져와야 할 경우 Java에서 제공하는 File.getParentFile() 함수를 사용할 수 있습니다. 이 문서에서는 이 함수를 사용하는 방법을 설명하고 코드 예제를 제공합니다. Java의 파일 클래스는 파일과 폴더를 조작하는 데 사용되는 주요 클래스입니다. 파일 속성을 얻고 조작하는 다양한 방법을 제공합니다.

Java의 File.getParent() 함수를 사용하여 파일의 상위 경로를 가져옵니다. Java의 File.getParent() 함수를 사용하여 파일의 상위 경로를 가져옵니다. Jul 24, 2023 pm 01:40 PM

Java의 File.getParent() 함수를 사용하여 파일의 상위 경로를 가져옵니다. Java 프로그래밍에서는 파일과 폴더를 조작해야 하는 경우가 많습니다. 때로는 파일이 있는 폴더의 경로인 파일의 상위 경로를 가져와야 하는 경우가 있습니다. Java의 File 클래스는 파일이나 폴더의 상위 경로를 가져오는 getParent() 메서드를 제공합니다. File 클래스는 파일 및 폴더에 대한 Java의 추상 표현입니다. 이는 파일 및 폴더를 작동하기 위한 일련의 메소드를 제공합니다. 그 중, 얻으세요.

Java에서 File.delete() 메소드를 사용하여 파일이나 디렉토리를 삭제하는 방법은 무엇입니까? Java에서 File.delete() 메소드를 사용하여 파일이나 디렉토리를 삭제하는 방법은 무엇입니까? Nov 18, 2023 am 08:02 AM

Java에서 File.delete() 메소드를 사용하여 파일이나 디렉토리를 삭제하는 방법은 무엇입니까? 개요: Java에서는 File 클래스의 delete() 메서드를 사용하여 파일이나 디렉터리를 삭제할 수 있습니다. 이 메소드는 지정된 파일이나 디렉토리를 삭제하는 데 사용됩니다. 그러나 이 방법은 다른 프로그램에서 열지 않은 빈 디렉터리나 파일만 삭제할 수 있다는 점에 유의해야 합니다. 파일 또는 디렉터리 삭제에 실패하는 경우 IOException을 포착하여 구체적인 이유를 찾을 수 있습니다. 1단계: 관련 패키지 가져오기 먼저, 다음이 필요합니다.

WebView 파일 도메인 원본 정책 우회 취약점 예시 분석 WebView 파일 도메인 원본 정책 우회 취약점 예시 분석 May 15, 2023 am 08:22 AM

Android 아키텍처에 대한 기본 지식. 커널 커널 계층 취약점은 매우 유해합니다. 다용도 드라이버는 많고 복잡하며, 또한 많은 취약점이 있을 수 있습니다. 라이브러리 시스템 런타임 라이브러리 계층 시스템 미들웨어는 libc, WebKit, SQLite 등을 포함한 런타임 라이브러리를 제공합니다. AndroidRunTimeDalvik 가상 머신 및 커널 라이브러리 FrameWork 애플리케이션 프레임워크 계층은 일련의 서비스 및 API 인터페이스를 제공합니다. 활동 관리자 콘텐츠 제공자 보기 리소스 관리자 알림 관리자 애플리케이션 애플리케이션 계층 시스템 애플리케이션 홈 화면 홈, 연락처 연락처, 전화 전화, 브라우저 기타 애플리케이션 개발자가 애플리케이션을 사용합니다. 프레임워크 레이어

See all articles