찾다
웹 프론트엔드JS 튜토리얼새로 고침 없이 페이지를 로드하려면 Yii 통합 pjax(pushstate+ajax)를 사용하세요.

이 기사에서는 페이지를 새로 고치지 않고 로드하기 위해 pjax(pushstate+ajax)를 통합하는 Yii를 소개합니다. 함께 배워봅시다

Pjax가 무엇인가요?

Pjax = history.pushState + Ajax
   = history.pushState + Async JS + XML(xhr?)

BOM 개체 기록이 향상되었습니다. 주로 기록 스택 작업을 위해 과거에는 전체 페이지를 이동하고 새로 고치는 교체, 이동 등만 있었습니다. 이제는 pushState가 있습니다. , replacementState 등 간단하게 히스토리 스택을 조작하는 방법은 히스토리 스택의 내용을 간단히 수정하는 것이며 부작용이 없습니다(페이지가 점프하거나 새로 고쳐지지 않음)

PJAX 효과

동적으로 로드된 콘텐츠 ajax는 URL을 통해 추적할 수 있습니다. 이 기술은 2단계 뷰 레이아웃이 있는 뷰에서 특히 유용합니다. 새로 고침 없이 페이지를 로드한다는 것은 응답 속도와 사용자 경험이 크게 향상되었음을 의미합니다. 정적 스크립트와 공통 모듈이 많을 때 재사용 비용이 최대한 절약됩니다. 애플리케이션 예제는 HTML5 pushState를 기반으로 구현된 현재 Google+, Facebook 및 새로운 버전의 Weibo를 참조할 수 있습니다. Google Plus의 성능이 가장 눈에 띕니다. 탐색 표시줄 주소를 클릭하면 화살표가 대상과 함께 이동하며 동시에 로드된 페이지가 페이드 인됩니다.

더티 URL 및 클린 URL

pjax가 등장하기 전에는 페이지를 새로 고치지 않고 로드하고 URL을 통해 추적하려면 브라우저에서 window.location.hash 속성을 지원해야 했습니다. url# 앵커 뒤에 기록된 주소를 판단하여 로드해야 할 콘텐츠를 결정하며, 구체적인 구성 방법은 해시 변경 모니터링 기능을 작성하고, 해시 변경이 트리거되면 로드할 콘텐츠를 판단합니다. 단점은 ie6과 같은 낮은 버전의 브라우저는 해시를 지원하지 않으며, 앞으로 및 뒤로 달성하려면 기록 URL을 기록하기 위해 추가 iframe을 구축해야 한다는 것입니다. 가장 큰 문제는 # 이후 생성된 콘텐츠가 검색 엔진에서 색인화되지 않는다는 것입니다. Google은 이전에 #!을 사용하여 주소를 ?escape_fragment=url로 안내하는 솔루션을 제공했습니다. , Renren, Sina Weibo 및 폐쇄된 Douban의 모든 사람들은 이 해시뱅이 사용되었거나 사용되고 있음을 확인했습니다. 통과하다#! 새로 고치지 않고 로드된 URL을 얻기 위해 일반적인 방법은 검색 엔진(국내 Baidu 등)에 포함되기 쉽지 않기 때문에 상대적으로 pjax는 clean url을 사용하여 동일한 효과를 얻을 수 있습니다. 다양한 A 브라우저와 호환이 잘 되기 때문에 지금 가장 적합한 방법은

PHP+jQuery를 사용하여 PJAX 구현

jQuery가 이미 오픈소스로 제공하고 있기 때문에 pushState 기반 자바스크립트 플러그인을 처음부터 작성할 필요가 없습니다. 쉽게 구현할 수 있습니다. 현재 개발 중인 프로젝트에 도입했는데, 웨이보 새 버전의 홍보는 말할 것도 없고, 원래의 모습과도 매우 잘 어울린다. 사용하고 나면 다음과 같습니다

시작 전 준비 사항:

1.jQ 기반 pjax 플러그인(github의 오픈 소스 프로젝트) https:/ /github.com/defunkt/jquery-pjax

3. PHP 프로젝트 코드 (쉬운 공유를 위해 이 글에서는 yii 프레임워크를 사용하여 시연하고 있으며, 실제 개발도 유사합니다.)

1. 프론트엔드 구현

사용하기 정말 간단하고 jquery-pjax 플러그인은 잘 패키지되어 있으며 기본 설정에 따라 확실히 사용자 정의할 수 있습니다(예: g plus의 효과 복사). 다음은 위의 내용을 통합한 기본 HTML 샘플 코드입니다. 단계:

<?php
Yii::app()->clientScript->registerCoreScript(&#39;jquery&#39;);
Yii::app()->clientScript->registerScriptFile(Yii::app()->baseUrl . &#39;/js/jquery-pjax/jquery.pjax.js&#39;);//具体以你存放pjax的实际位置为准
?>
<p id="nav">
  <a href="<?php echo Yii::app()->createUrl(&#39;article/index&#39;);?>">article</a>
</p>
<p id="main">替换的内容</p>
<script type="text/javascript">
  $(document).ready(function(){
    $("#main").pjax("a");
  });
</script>

궁극적인 목표는 a 태그를 클릭하는 것이며, ajax를 통해 반환된 결과는 main의 id와 함께 p에 포함됩니다. 텍스트는 해당 주소 콘텐츠로 대체되고, URL은 자동으로 업데이트됩니다. 페이지가 다시 로드되지 않습니다. 백엔드에서 처리할 콘텐츠 구현을 시작해 보겠습니다

2. PHP 측 구현

PHP 측에서 처리해야 하는 작업은 주로 두 가지입니다. 1. 레이아웃 뷰 레이아웃 구현 2. 요청 판단 pjax에서 옵니다

Yii 프레임워크에서 구현:

컨트롤러에서 작업을 다음과 같이 처리합니다(예를 들어 Article 색인 사용).

public function actionIndex() {
  $this->layout = &#39;//layouts/column1&#39;;
  $dataProvider = new CActiveDataProvider(&#39;Article&#39;, array(
    &#39;criteria&#39; => array(&#39;order&#39; => &#39;create_time DESC&#39;)
  ));
  if (array_key_exists(&#39;HTTP_X_PJAX&#39;, $_SERVER) && $_SERVER[&#39;HTTP_X_PJAX&#39;]) {
    $this->renderPartial(&#39;index&#39;, array(
       &#39;dataProvider&#39; => $dataProvider,
    ));
  } else {
    $this->render(&#39;index&#39;, array(
      &#39;dataProvider&#39; => $dataProvider,
    ));
  }
}

효과 데모 사진:

기사 링크나 기사 링크를 클릭하면 다음 효과 페이지가 나타납니다 :

----------------------------- ------------

jquery-pjax 사용 시 주의 사항:

1. 반환된 템플릿 콘텐츠는 일반 텍스트일 수 없으며 html 태그로 래핑해야 합니다

2. 플러그인을 사용하려면 자세한 내용은 github 프로젝트 설명을 참조하세요. 업데이트 후 사용 방법이 다를 수 있습니다

3. pushstate를 지원하지 않는 낮은 버전의 브라우저의 경우 pjax 플러그인이 자동으로 결정하여 사용합니다. 기존 페이지 로딩 모드

4. 페이지의 pjax 요청 시간이 설정된 시간을 초과하면 새로 고침을 사용하여 로드되며 모든 사람을 위해 플러그인

의 관련 매개변수를 조정해야 합니다. . 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

Jquery를 PHP와 결합하여 AJAX 긴 폴링 구현

js 로드 시 ajax 진행 바코드

JavaScript, Ajax, jQuery에 대한 사전 이해 및 세 가지 간의 관계 비교

위 내용은 새로 고침 없이 페이지를 로드하려면 Yii 통합 pjax(pushstate+ajax)를 사용하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
JavaScript 프레임 워크 : 현대적인 웹 개발 파워JavaScript 프레임 워크 : 현대적인 웹 개발 파워May 02, 2025 am 12:04 AM

JavaScript 프레임 워크의 힘은 개발 단순화, 사용자 경험 및 응용 프로그램 성능을 향상시키는 데 있습니다. 프레임 워크를 선택할 때 : 1. 프로젝트 규모와 복잡성, 2. 팀 경험, 3. 생태계 및 커뮤니티 지원.

JavaScript, C 및 브라우저의 관계JavaScript, C 및 브라우저의 관계May 01, 2025 am 12:06 AM

서론 나는 당신이 이상하다는 것을 알고 있습니다. JavaScript, C 및 Browser는 정확히 무엇을해야합니까? 그들은 관련이없는 것처럼 보이지만 실제로는 현대 웹 개발에서 매우 중요한 역할을합니다. 오늘 우리는이 세 가지 사이의 밀접한 관계에 대해 논의 할 것입니다. 이 기사를 통해 브라우저에서 JavaScript가 어떻게 실행되는지, 브라우저 엔진의 C 역할 및 웹 페이지의 렌더링 및 상호 작용을 유도하기 위해 함께 작동하는 방법을 알게됩니다. 우리는 모두 JavaScript와 브라우저의 관계를 알고 있습니다. JavaScript는 프론트 엔드 개발의 핵심 언어입니다. 브라우저에서 직접 실행되므로 웹 페이지를 생생하고 흥미롭게 만듭니다. 왜 Javascr

Node.js는 TypeScript가있는 스트림입니다Node.js는 TypeScript가있는 스트림입니다Apr 30, 2025 am 08:22 AM

Node.js는 크림 덕분에 효율적인 I/O에서 탁월합니다. 스트림은 메모리 오버로드를 피하고 큰 파일, 네트워크 작업 및 실시간 애플리케이션을위한 메모리 과부하를 피하기 위해 데이터를 점차적으로 처리합니다. 스트림을 TypeScript의 유형 안전과 결합하면 Powe가 생성됩니다

Python vs. JavaScript : 성능 및 효율성 고려 사항Python vs. JavaScript : 성능 및 효율성 고려 사항Apr 30, 2025 am 12:08 AM

파이썬과 자바 스크립트 간의 성능과 효율성의 차이는 주로 다음과 같이 반영됩니다. 1) 해석 된 언어로서, 파이썬은 느리게 실행되지만 개발 효율이 높고 빠른 프로토 타입 개발에 적합합니다. 2) JavaScript는 브라우저의 단일 스레드로 제한되지만 멀티 스레딩 및 비동기 I/O는 Node.js의 성능을 향상시키는 데 사용될 수 있으며 실제 프로젝트에서는 이점이 있습니다.

JavaScript의 기원 : 구현 언어 탐색JavaScript의 기원 : 구현 언어 탐색Apr 29, 2025 am 12:51 AM

JavaScript는 1995 년에 시작하여 Brandon Ike에 의해 만들어졌으며 언어를 C로 실현했습니다. 1.C Language는 JavaScript의 고성능 및 시스템 수준 프로그래밍 기능을 제공합니다. 2. JavaScript의 메모리 관리 및 성능 최적화는 C 언어에 의존합니다. 3. C 언어의 크로스 플랫폼 기능은 자바 스크립트가 다른 운영 체제에서 효율적으로 실행하는 데 도움이됩니다.

무대 뒤에서 : 어떤 언어의 힘이 자바 스크립트입니까?무대 뒤에서 : 어떤 언어의 힘이 자바 스크립트입니까?Apr 28, 2025 am 12:01 AM

JavaScript는 브라우저 및 Node.js 환경에서 실행되며 JavaScript 엔진을 사용하여 코드를 구문 분석하고 실행합니다. 1) 구문 분석 단계에서 초록 구문 트리 (AST)를 생성합니다. 2) 컴파일 단계에서 AST를 바이트 코드 또는 기계 코드로 변환합니다. 3) 실행 단계에서 컴파일 된 코드를 실행하십시오.

파이썬과 자바 스크립트의 미래 : 트렌드와 예측파이썬과 자바 스크립트의 미래 : 트렌드와 예측Apr 27, 2025 am 12:21 AM

Python 및 JavaScript의 미래 추세에는 다음이 포함됩니다. 1. Python은 과학 컴퓨팅 분야에서의 위치를 ​​통합하고 AI, 2. JavaScript는 웹 기술의 개발을 촉진하고, 3. 교차 플랫폼 개발이 핫한 주제가되고 4. 성능 최적화가 중점을 둘 것입니다. 둘 다 해당 분야에서 응용 프로그램 시나리오를 계속 확장하고 성능이 더 많은 혁신을 일으킬 것입니다.

Python vs. JavaScript : 개발 환경 및 도구Python vs. JavaScript : 개발 환경 및 도구Apr 26, 2025 am 12:09 AM

개발 환경에서 Python과 JavaScript의 선택이 모두 중요합니다. 1) Python의 개발 환경에는 Pycharm, Jupyternotebook 및 Anaconda가 포함되어 있으며 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 2) JavaScript의 개발 환경에는 Node.js, VScode 및 Webpack이 포함되어 있으며 프론트 엔드 및 백엔드 개발에 적합합니다. 프로젝트 요구에 따라 올바른 도구를 선택하면 개발 효율성과 프로젝트 성공률이 향상 될 수 있습니다.

See all articles

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

맨티스BT

맨티스BT

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

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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