Table of Contents
Detailed explanation of how to use modal pop-up window in yii2 combined with gridview. In the previous article, yii2gridview
Home Backend Development PHP Tutorial Detailed explanation of how to use modal pop-up window example code in combination with gridview in yii2, yii2gridview_PHP tutorial

Detailed explanation of how to use modal pop-up window example code in combination with gridview in yii2, yii2gridview_PHP tutorial

Jul 12, 2016 am 08:49 AM
modal yii2

Detailed explanation of how to use modal pop-up window in yii2 combined with gridview. In the previous article, yii2gridview

introduced to you how to use modal pop-up window in Yii2 (basic use), that is Take creation as an example.

In actual development, we often encounter situations where modal is used to modify the data on the list page. If it is a general loop display, I believe most people can operate it after seeing the basic use of modal. However, it is estimated that some people will be able to operate it when combined with gridview. It’s starting to get too much, let’s see how to solve this problem!

1. Add an [Update] button to the gridview operation, and specify the value of data-toggle data-target class and data-id

1

2

3

4

5

6

7

8

9

10

11

12

13

14

[

'class' => 'yii\grid\ActionColumn',

'template' => '{update}',

'buttons' => [

'update' => function ($url, $model, $key) {

return Html::a('更新', '#', [

'data-toggle' => 'modal',

'data-target' => '#update-modal',

'class' => 'data-update',

'data-id' => $key,

]);

},

],

],

Copy after login

2. Add modal for update

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<&#63;php

use yii\bootstrap\Modal;

// 更新操作

Modal::begin([

'id' => 'update-modal',

'header' => '<h4 class="modal-title">更新</h4>',

'footer' => '<a href="#" class="btn btn-primary" data-dismiss="modal">Close</a>',

]);

$requestUpdateUrl = Url::toRoute('update');

$updateJs = <<<JS

$('.data-update').on('click', function () {

$.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') },

function (data) {

$('.modal-body').html(data);

}

);

});

Copy after login

JS;

1

2

3

$this->registerJs($updateJs);

Modal::end();

&#63;>

Copy after login

3. Modify our update method

1

2

3

4

5

6

7

8

9

10

11

public function actionUpdate($id)

{

$model = $this->findModel($id);

if ($model->load(Yii::$app->request->post()) && $model->save()) {

return $this->redirect(['index']);

} else {

return $this->renderAjax('update', [

'model' => $model,

]);

}

}

Copy after login

It can be seen that the whole process is no different from the basic use of modal we mentioned before. But it doesn’t end here. I believe most people may encounter the following common problems that are difficult to solve:

select2 is used in yii2 modal. Why is the search box not searchable?

yii2 There are multiple modals on a single page. Why do the pages share one page and wait until the data is loaded?

yii2 A single page has multiple modals. Take modal as an example when adding a single page and updating the gridview above. When using select2, why does the updated select2 become invalid and ineffective?

Let’s see how to solve these problems one by one:

First of all, the first question is that you only need to specify the tabindex of the options option to false when modal uses begin. The reference is as follows:

1

2

3

4

5

6

Modal::begin([

// ......

'options' => [

'tabindex' => false

],

]);

Copy after login

The second and third problems are caused by using multiple modals in a single page. To illustrate the problem, we use modals in both the [Create] button in a list and the [Update] button in the gridview. . According to how to use modal pop-ups in Yii2 (basic use) and this article, the first problem is obviously

1

$('.modal-body').html(data);

Copy after login

Caused by multiple modals, after we use the modal for the first time, values ​​are assigned to the bodies of all modals, so that when other modals are used later, the same content is displayed before the data is requested. To solve this problem, you only need to assign a separate value to the respective modal-body after each asynchronous request. The code can be referenced as follows:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

$('#create').on('click', function () {

$.get('url', {},

function (data) {

$('#create-modal').find('.modal-body').html(data);

// $('.modal-body').html(data);

}

);

});

$('.data-update').on('click', function () {

$.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') },

function (data) {

$('#update-modal').find('.modal-body').html(data);

// $('.modal-body').html(data);

}

);

});

Copy after login

Look at the last question, students who have used select2 should pay attention! ! !

If like the example introduced in this topic, if select2 is included in the form, it will cause the select2 field to be normal only during [create], and the select2 field will be "hidden" during the [update] operation!

This is actually caused by the ID corresponding to the same select2 on the same page. To solve this problem, you only need to remove all existing form items on the page before each asynchronous request for data. See the specific implementation:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

$('#create').on('click', function () {

// 有效避免multiply modal select2的问题

// 移除异步加载过来的form表单

$('.document-nav-form').remove();

$.get('{$requestUrl}', {},

function (data) {

$('#create-modal').find('.modal-body').html(data);

}

);

});

$('.data-update').on('click', function () {

// 有效避免multiply modal select2的问题

// 移除异步加载过来的form表单

$('.document-nav-form').remove();

$.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') },

function (data) {

$('#update-modal').find('.modal-body').html(data);

}

);

});

Copy after login

The above is the entire description of the example code of how to use modal pop-up window combined with gridview in yii2 introduced by the editor. I hope it will be helpful to you. If you have any questions, please leave me a message and the editor will promptly Reply to everyone. I would also like to thank you all for your support of the Bangkejia website!

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1136665.htmlTechArticleDetailed explanation of how to use modal pop-up window example code in yii2 combined with gridview, yii2gridview introduced you to Yii2 in the previous article How to use the modal pop-up window (basic use), take creation as an example. Real...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1670
14
PHP Tutorial
1274
29
C# Tutorial
1256
24
Explain secure password hashing in PHP (e.g., password_hash, password_verify). Why not use MD5 or SHA1? Explain secure password hashing in PHP (e.g., password_hash, password_verify). Why not use MD5 or SHA1? Apr 17, 2025 am 12:06 AM

In PHP, password_hash and password_verify functions should be used to implement secure password hashing, and MD5 or SHA1 should not be used. 1) password_hash generates a hash containing salt values ​​to enhance security. 2) Password_verify verify password and ensure security by comparing hash values. 3) MD5 and SHA1 are vulnerable and lack salt values, and are not suitable for modern password security.

PHP and Python: Comparing Two Popular Programming Languages PHP and Python: Comparing Two Popular Programming Languages Apr 14, 2025 am 12:13 AM

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

PHP in Action: Real-World Examples and Applications PHP in Action: Real-World Examples and Applications Apr 14, 2025 am 12:19 AM

PHP is widely used in e-commerce, content management systems and API development. 1) E-commerce: used for shopping cart function and payment processing. 2) Content management system: used for dynamic content generation and user management. 3) API development: used for RESTful API development and API security. Through performance optimization and best practices, the efficiency and maintainability of PHP applications are improved.

How does PHP type hinting work, including scalar types, return types, union types, and nullable types? How does PHP type hinting work, including scalar types, return types, union types, and nullable types? Apr 17, 2025 am 12:25 AM

PHP type prompts to improve code quality and readability. 1) Scalar type tips: Since PHP7.0, basic data types are allowed to be specified in function parameters, such as int, float, etc. 2) Return type prompt: Ensure the consistency of the function return value type. 3) Union type prompt: Since PHP8.0, multiple types are allowed to be specified in function parameters or return values. 4) Nullable type prompt: Allows to include null values ​​and handle functions that may return null values.

The Enduring Relevance of PHP: Is It Still Alive? The Enduring Relevance of PHP: Is It Still Alive? Apr 14, 2025 am 12:12 AM

PHP is still dynamic and still occupies an important position in the field of modern programming. 1) PHP's simplicity and powerful community support make it widely used in web development; 2) Its flexibility and stability make it outstanding in handling web forms, database operations and file processing; 3) PHP is constantly evolving and optimizing, suitable for beginners and experienced developers.

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

How do you prevent SQL Injection in PHP? (Prepared statements, PDO) How do you prevent SQL Injection in PHP? (Prepared statements, PDO) Apr 15, 2025 am 12:15 AM

Using preprocessing statements and PDO in PHP can effectively prevent SQL injection attacks. 1) Use PDO to connect to the database and set the error mode. 2) Create preprocessing statements through the prepare method and pass data using placeholders and execute methods. 3) Process query results and ensure the security and performance of the code.

PHP and Python: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

See all articles