国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
鑰匙要點
ajax form

如何在drupal 8?

中創(chuàng)建一個自定義AJAX命令來創(chuàng)建Drupal 8中的自定義AJAX命令,您需要創(chuàng)建一個實現(xiàn)CommandInterface的新類。該類應定義一種渲染方法,該方法返回帶有以下鍵的數(shù)組:“命令”,這是命令的名稱和“方法”,這是在客戶端端被調(diào)用的方法。該數(shù)組還可以包含將傳遞給客戶端方法的其他數(shù)據(jù)。

>

的頁面上的多個元素Drupal 8中的頁面上的多個元素,您可以在AJAX響應對像中返回多個命令。每個命令應指定要更新的元素和要執(zhí)行的操作。這些命令將以將它們添加到響應對象的順序中執(zhí)行。
> Drupal 8中的頁面上的元素,您可以使用“替換”命令。此命令需要兩個參數(shù):要替換元素的選擇器和新內(nèi)容。選擇器可以是任何有效的jQuery選擇器。
>
>使用ajax將內(nèi)容插入Drupal 8中的頁面,您可以使用“插入”命令。此命令需要兩個參數(shù):將插入內(nèi)容的元素的選擇器和新內(nèi)容??梢栽谒x元素之前,之後或內(nèi)部插入內(nèi)容。
>我如何使用Ajax在Drupal 8?
>如何使用Ajax重定向到Drupal 8中的其他頁面。使用“重定向”命令。此命令需要一個參數(shù):重定向到頁面的URL。 URL可以是任何有效的URL。
首頁 後端開發(fā) php教程 在Drupal 8中使用AJAX表格

在Drupal 8中使用AJAX表格

Feb 17, 2025 pm 12:53 PM

在Drupal 8中使用AJAX表格

鑰匙要點

  • > Drupal 8 Ajax API允許無需JavaScript代碼清潔,用戶友好的表單。這可以通過消除表格的某些行為來實現(xiàn)。
  • >
  • >可以將電子郵件驗證邏輯移至AJAX回調(diào),該回調(diào)觸發(fā)驗證並打印消息而無需提交表單。這是形式的常見行為,是理解Drupal 8中Ajax的良好練習。
  • ajax API允許自定義形式行為。表單類中的AJAX回調(diào)方法接收表單數(shù)組和表單狀態(tài)對象,執(zhí)行驗證並根據(jù)驗證結果返回帶有多個命令的AJAX響應。 >
  • ajax也可以在表單外部的drupal 8中使用,例如將use-ajax類添加到任何鏈接中。這允許Drupal在單擊鏈接時向HREF屬性中的URL提出AJAX請求,返回AJAX命令並根據(jù)需要執(zhí)行各種操作。
  • 在本文中,我將向您展示使用Drupal 8 Ajax API的干淨方法,而無需編寫一行JavaScript代碼。為此,我們將回到上一篇文章中為Drupal 8構建的第一個自定義表單,並
  • ajaxify
它的某些行為,以使其更加用戶友好。

>該表格的更新版本可以在此存儲庫中以名稱DemoForm(演示模塊)找到。我們在本文中編寫的代碼也可以在此處找到,但在一個稱為Ajax的單獨分支中。我建議您克隆回購,並在開發(fā)環(huán)境中安裝模塊。

在Drupal 8中使用AJAX表格 DemoForm

>儘管命名較差,但該模型在說明Drupal 8中編寫自定義表單的基礎方面非常有幫助。它處理驗證,配置並體現(xiàn)了通常的API的使用。當然,它專注於基礎知識,沒有任何壯觀的事情。

>如果您記得或檢查代碼,您會看到該表格顯示一個單一的文本字段,負責收集以保存為配置的電子郵件地址。表單驗證負責確保提交的電子郵件具有.com結尾(對此進行了不良嘗試,但足以說明表單驗證的原則)。因此,當用戶提交表單時,他們將新的電子郵件地址保存到配置中,並將確認消息打印到屏幕上。

在本文中,我們將將電子郵件驗證邏輯移至AJAX回調(diào),以便在用戶完成鍵入電子郵件地址後,驗證將自動觸發(fā),並在不提交表單的情況下打印了消息。同樣,這種行為沒有什麼壯觀的,您會經(jīng)常以野外形式看到它(通常是為了驗證用戶名)。但這是在Drupal 8中查看Ajax的一個很好的練習。

>

ajax form

我們需要做的第一件事是將電子郵件驗證邏輯從一般validateForm()移動到僅處理此方面的方法:

<span>/**
</span><span> * Validates that the email field is correct.
</span><span> */
</span><span>protected function validateEmail(array &$form, FormStateInterface $form_state) {
</span>  <span>if (substr($form_state->getValue('email'), -4) !== '.com') {
</span>    <span>return FALSE;
</span>  <span>}
</span>  <span>return TRUE;
</span><span>}</span>

您可能會注意到,我們還對邏輯進行了一些更改,以確保電子郵件地址以.com

結束。 然後,我們可以從主要驗證方法中遵守此邏輯,以確保我們的現(xiàn)有行為仍然有效:

即使我們的表單以某種方式提交(通過程序或其他方式),
<span>/**
</span><span> * <span>{@inheritdoc}
</span></span><span> */
</span><span>public function validateForm(array &$form, FormStateInterface $form_state) {
</span>  <span>// Validate email.
</span>  <span>if (!$this->validateEmail($form, $form_state)) {
</span>    <span>$form_state->setErrorByName('email', $this->t('This is not a .com email address.'));
</span>  <span>}
</span><span>}</span>
即使我們的表格仍將運行。

接下來,我們需要轉到我們的表單定義,特別是電子郵件字段,並根據(jù)用戶互動使其觸發(fā)Ajax請求。這將是用戶更改字段價值並從中刪除焦點的行為:>

我們在這裡做的新工作是用一些相關鍵向數(shù)組中添加#AJAX鍵。此外,我們在表單元素之後添加了一些標記,作為有關電子郵件有效性的簡短消息包裝器。
<span>$form['email'] = array(
</span>  <span>'#type' => 'email',
</span>  <span>'#title' => $this->t('Your .com email address.'),
</span>  <span>'#default_value' => $config->get('demo.email_address'),
</span>  <span>'#ajax' => [
</span>    <span>'callback' => array($this, 'validateEmailAjax'),
</span>    <span>'event' => 'change',
</span>    <span>'progress' => array(
</span>      <span>'type' => 'throbber',
</span>      <span>'message' => t('Verifying email...'),
</span>    <span>),
</span>  <span>],
</span>  <span>'#suffix' => '<span ></span>'
</span><span>);</span>
。

> #AJAX數(shù)組內(nèi)部的回調(diào)指向我們的表單類(ValidateMailajax())中的方法,而事件將javaScript綁定到此表單元素的jQuery Change事件中。另外,您還可以指定一個路徑密鑰,而不是回調(diào),但是在我們的情況下,這意味著還必須設置一個似乎冗餘的路由和控制器。而且我們不希望包裝器密鑰,因為我們不打算填充帶有返回內(nèi)容的區(qū)域,而是想詳細介紹回調(diào)所產(chǎn)生的操作。為此,我們將使用ajax命令。

要了解所有這些,我鼓勵您查閱AJAX API頁面或AJAX的表格API條目。您可以使用少數(shù)其他選項來進一步自定義表單元素的Ajax行為。

>

>現(xiàn)在是時候在我們的表單類中寫下回調(diào)方法了。這將接收$ form array和$ form_state對象,作為來自觸發(fā)ajax請求的表單的參數(shù):>

簡單地說,在此方法中,我們執(zhí)行驗證並返回帶有多個命令的AJAX響應,這些命令取決於驗證結果。使用CSSCommand,我們將一些CSS直接應用於電子郵件表單元素,而使用HTMLCommand,我們替換了指定的選擇器的內(nèi)容(請記住我們的表單元素中的後綴嗎?)。

<span>/**
</span><span> * Ajax callback to validate the email field.
</span><span> */
</span><span>public function validateEmailAjax(array &$form, FormStateInterface $form_state) {
</span>  <span>$valid = $this->validateEmail($form, $form_state);
</span>  <span>$response = new AjaxResponse();
</span>  <span>if ($valid) {
</span>    <span>$css = ['border' => '1px solid green'];
</span>    <span>$message = $this->t('Email ok.');
</span>  <span>}
</span>  <span>else {
</span>    <span>$css = ['border' => '1px solid red'];
</span>    <span>$message = $this->t('Email not valid.');
</span>  <span>}
</span>  <span>$response->addCommand(new CssCommand('#edit-email', $css));
</span>  <span>$response->addCommand(new HtmlCommand('.email-valid-message', $message));
</span>  <span>return $response;
</span><span>}</span>
這些命令幾乎將其映射到jQuery函數(shù),因此它們很容易掌握。您可以在此頁面上找到所有可用命令的列表。而且,由於我們在此方法中使用了三個新類,因此我們必須記住

在頂部使用:
<span>/**
</span><span> * Validates that the email field is correct.
</span><span> */
</span><span>protected function validateEmail(array &$form, FormStateInterface $form_state) {
</span>  <span>if (substr($form_state->getValue('email'), -4) !== '.com') {
</span>    <span>return FALSE;
</span>  <span>}
</span>  <span>return TRUE;
</span><span>}</span>

>就是這樣。如果您清除緩存並重新加載表單,則輸入電子郵件字段並刪除焦點將觸發(fā)回調(diào)以驗證電子郵件地址。您會注意到那裡的小動物圖標(可以在定義中更改)以及我們定義的簡短消息。 a正確的電子郵件地址應以綠色突出顯示字段,並在相反的顏色紅色時打印出確定的消息。

如果我們在表單元素定義中指定了包裝器,我們本可以返回某些內(nèi)容(或渲染數(shù)組),這些內(nèi)容將放置在該選擇器內(nèi)部。因此,您可以選擇在返回內(nèi)容或AJAX命令之間進行選擇,但我建議在大多數(shù)情況下使用後者,因為它們提供了更靈活(且一致)的行為。

結論

在本文中,我們看到了使用Ajax改善我們的表單並使最終用戶更友好的示例。我們已經(jīng)寫了零行的javaScript行以實現(xiàn)這一目標。

> 在我們的情況下,這確實是一個偏好或fancification

>表格是您在Drupal 8中看到Ajax的主要領域,但是您可以在不編寫JavaScript的情況下利用它的其他幾種方法。

>曾經(jīng)是不錯的方法是在任何鏈接上添加使用ajax類。每當單擊鏈接時,這將在HREF屬性中向URL提出Drupal請求。從回調(diào)中,您可以返回AJAX命令並根據(jù)需要執(zhí)行各種操作。但是請記住,jQuery和其他核心腳本並未在匿名用戶的所有頁面上加載(因此,Ajax將優(yōu)雅地降低到常規(guī)鏈接行為)。因此,請確保如果需要此行為,請確保為匿名用戶包含這些腳本。 > 在Drupal 8表格中使用Ajax的常見問題

>如何在Drupal 8表格中實現(xiàn)Ajax?首先,您需要定義一個包含AJAX回調(diào)的表單。這可以通過表格的buildform方法完成。應將“ #AJAX”屬性添加到將觸發(fā)Ajax請求的表單元素中。該屬性是一個包括“回調(diào)”密鑰的數(shù)組,該數(shù)組指定觸發(fā)表單元素時要調(diào)用的方法?;卣{(diào)方法應返回一個ajax響應對象,該對象定義了頁面上應更新的內(nèi)容。

>

如何在drupal 8?

中創(chuàng)建一個自定義AJAX命令來創(chuàng)建Drupal 8中的自定義AJAX命令,您需要創(chuàng)建一個實現(xiàn)CommandInterface的新類。該類應定義一種渲染方法,該方法返回帶有以下鍵的數(shù)組:“命令”,這是命令的名稱和“方法”,這是在客戶端端被調(diào)用的方法。該數(shù)組還可以包含將傳遞給客戶端方法的其他數(shù)據(jù)。

>

>我如何處理drupal 8?

>

處理drupal 8中的ajax錯誤使用表單元素的“ #AJAX”屬性中的“錯誤”密鑰。此密鑰指定了一種回調(diào)方法,如果在AJAX請求期間發(fā)生錯誤,該鍵將被調(diào)用。回調(diào)方法應返回一個定義如何處理錯誤的ajax響應對象。

>我如何使用ajax更新drupal 8?

的頁面上的多個元素Drupal 8中的頁面上的多個元素,您可以在AJAX響應對像中返回多個命令。每個命令應指定要更新的元素和要執(zhí)行的操作。這些命令將以將它們添加到響應對象的順序中執(zhí)行。

>

>我如何使用ajax替換drupal 8?

>

> Drupal 8中的頁面上的元素,您可以使用“替換”命令。此命令需要兩個參數(shù):要替換元素的選擇器和新內(nèi)容。選擇器可以是任何有效的jQuery選擇器。

>

我如何使用ajax從drupal 8?

中的頁面中刪除元素,您可以使用“刪除”命令。此命令需要一個參數(shù):要刪除元素的選擇器。選擇器可以是任何有效的jQuery選擇器。

>

我如何使用ajax將內(nèi)容插入drupal 8?

>

>使用ajax將內(nèi)容插入Drupal 8中的頁面,您可以使用“插入”命令。此命令需要兩個參數(shù):將插入內(nèi)容的元素的選擇器和新內(nèi)容??梢栽谒x元素之前,之後或內(nèi)部插入內(nèi)容。

>

>我如何使用Ajax在Drupal 8?

中顯示警報消息,使用Ajax在Drupal 8中顯示警報消息,您可以使用“警報”命令。此命令需要一個參數(shù):要顯示消息。該消息可以是任何有效的字符串。

>如何使用Ajax重定向到Drupal 8中的其他頁面。使用“重定向”命令。此命令需要一個參數(shù):重定向到頁面的URL。 URL可以是任何有效的URL。

以上是在Drupal 8中使用AJAX表格的詳細內(nèi)容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內(nèi)容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何在PHP中實施身份驗證和授權? 如何在PHP中實施身份驗證和授權? Jun 20, 2025 am 01:03 AM

tosecurelyhandleauthenticationandationallizationInphp,lofterTheSesteps:1.AlwaysHashPasswordSwithPassword_hash()andverifyusingspasspassword_verify(),usepreparedStatatementStopreventsqlineptions,andStoreSeruserDatain usseruserDatain $ _sessiveferterlogin.2.implementrole-2.imaccessccsccccccccccccccccccccccccc.

我如何了解最新的PHP開發(fā)和最佳實踐? 我如何了解最新的PHP開發(fā)和最佳實踐? Jun 23, 2025 am 12:56 AM

TostaycurrentwithPHPdevelopmentsandbestpractices,followkeynewssourceslikePHP.netandPHPWeekly,engagewithcommunitiesonforumsandconferences,keeptoolingupdatedandgraduallyadoptnewfeatures,andreadorcontributetoopensourceprojects.First,followreliablesource

什麼是PHP,為什麼它用於Web開發(fā)? 什麼是PHP,為什麼它用於Web開發(fā)? Jun 23, 2025 am 12:55 AM

PHPbecamepopularforwebdevelopmentduetoitseaseoflearning,seamlessintegrationwithHTML,widespreadhostingsupport,andalargeecosystemincludingframeworkslikeLaravelandCMSplatformslikeWordPress.Itexcelsinhandlingformsubmissions,managingusersessions,interacti

如何設置PHP時區(qū)? 如何設置PHP時區(qū)? Jun 25, 2025 am 01:00 AM

tosetTherightTimeZoneInphp,restate_default_timezone_set()functionAtthestArtofyourscriptWithavalIdidentIdentifiersuchas'america/new_york'.1.usedate_default_default_timezone_set_set()

如何在操作系統(tǒng)(Windows,MacOS,Linux)上安裝PHP? 如何在操作系統(tǒng)(Windows,MacOS,Linux)上安裝PHP? Jun 20, 2025 am 01:02 AM

安裝PHP的方法因操作系統(tǒng)而異,以下是具體步驟:1.Windows用戶可使用XAMPP一鍵安裝包或手動配置,下載XAMPP並安裝,選擇PHP組件或將PHP加入環(huán)境變量;2.macOS用戶可通過Homebrew安裝PHP,運行相應命令安裝並配置Apache服務器;3.Linux用戶(Ubuntu/Debian)可使用APT包管理器更新源後安裝PHP及常用擴展,並通過創(chuàng)建測試文件驗證安裝是否成功。

我如何驗證PHP中的用戶輸入以確保其符合某些標準? 我如何驗證PHP中的用戶輸入以確保其符合某些標準? Jun 22, 2025 am 01:00 AM

TovalidateuserinputinPHP,usebuilt-invalidationfunctionslikefilter_var()andfilter_input(),applyregularexpressionsforcustomformatssuchasusernamesorphonenumbers,checkdatatypesfornumericvalueslikeageorprice,setlengthlimitsandtrimwhitespacetopreventlayout

如何使用session_destroy()在PHP中破壞會話? 如何使用session_destroy()在PHP中破壞會話? Jun 20, 2025 am 01:06 AM

要完全銷毀PHP中的會話,必須先調(diào)用session_start()啟動會話,再調(diào)用session_destroy()刪除所有會話數(shù)據(jù)。 1.首先使用session_start()確保會話已啟動;2.然後調(diào)用session_destroy()清除會話數(shù)據(jù);3.可選但推薦:手動unset$_SESSION數(shù)組以清除全局變量;4.同時刪除會話cookie,防止用戶保留會話狀態(tài);5.最後注意在銷毀後重定向用戶,並避免立即復用會話變量,否則需重新啟動會話。這樣做能確保用戶徹底退出系統(tǒng),不留殘留信息。

什麼是php(serialize(),Unserialize())中的數(shù)據(jù)序列化? 什麼是php(serialize(),Unserialize())中的數(shù)據(jù)序列化? Jun 22, 2025 am 01:03 AM

thephpfunctionserize()andunSerialize()redustoconvertComplexdatStructDestoresToroStoroStoroSandaBackagagain.1.Serialize()

See all articles