จะเพิ่มฟิลด์ใหม่ในหน้าลงทะเบียนใน magento2 ได้อย่างไร


คำตอบ:


6

หากคุณต้องการเพิ่มฟิลด์ใหม่ในบัญชีลูกค้าคุณต้องแทนที่register.phtmlในธีมที่กำหนดเองของคุณ

สร้างธีมที่กำหนดเองจากนั้นสร้างregister.phtmlในพา ธ ดังต่อไปนี้

app / ออกแบบ / ส่วนหน้า / ผู้ขาย / ธีม / Magento_Customer / แม่แบบ / รูปแบบ / register.phtml

จากนั้นคัดลอกรหัสจากโมดูลลูกค้า / ดู / frontend / แม่แบบ / form / register.phtmlและวางไฟล์ที่สร้างไว้ด้านบน

จากนั้นเพิ่มฟิลด์ที่กำหนดเองของคุณ :

<div class="field required">
    <label for="custom_field" class="label"><span><?= __('CustomField') ?></span></label>
    <div class="control">
        <input type="text" name="custom_field" id="custom_field" value="<?= $block->escapeHtml($block->getFormData()->getCustomField()) ?>" title="<?= __('CustomField') ?>" class="input-text" data-validate="{required:true, 'validate-phoneStrict':true}">
    </div>
</div>

ก่อนที่คุณจะทำเช่นนั้นคุณต้องสร้างแอตทริบิวต์ของลูกค้าสำหรับcustom_fieldของคุณเพื่อจัดเก็บฐานข้อมูล

สร้างแอตทริบิวต์ลูกค้า:

คุณต้องสร้างโมดูลที่กำหนดเองเพื่อทำหลังจากสร้างโมดูลที่กำหนดเอง

สร้าง InstallData.php ในพา ธ ดังต่อไปนี้ Vendor \ Module \ Setup

InstallData.php

ในรหัสด้านล่างนี้ฉันได้เพิ่มคุณสมบัติcustom_field

  <?php
  /**
   * Copyright © 2016 Magento. All rights reserved.
   * See COPYING.txt for license details.
   */
  namespace Vendor\Module\Setup;

  use Magento\Customer\Setup\CustomerSetupFactory;
  use Magento\Customer\Model\Customer;
  use Magento\Eav\Model\Entity\Attribute\Set as AttributeSet;
  use Magento\Eav\Model\Entity\Attribute\SetFactory as AttributeSetFactory;
  use Magento\Framework\Setup\InstallDataInterface;
  use Magento\Framework\Setup\ModuleContextInterface;
  use Magento\Framework\Setup\ModuleDataSetupInterface;

  /**
   * Install data
   * @codeCoverageIgnore
   */
  class InstallData implements InstallDataInterface
  {

      /**
       * CustomerSetupFactory
       * @var CustomerSetupFactory
       */
      protected $customerSetupFactory;

      /**
       * $attributeSetFactory
       * @var AttributeSetFactory
       */
      private $attributeSetFactory;

      /**
       * initiate object
       * @param CustomerSetupFactory $customerSetupFactory
       * @param AttributeSetFactory $attributeSetFactory
       */
      public function __construct(
          CustomerSetupFactory $customerSetupFactory,
          AttributeSetFactory $attributeSetFactory
      )
      {
          $this->customerSetupFactory = $customerSetupFactory;
          $this->attributeSetFactory = $attributeSetFactory;
      }

      /**
       * install data method
       * @param ModuleDataSetupInterface $setup
       * @param ModuleContextInterface $context
       */
      public function install(ModuleDataSetupInterface $setup, ModuleContextInterface $context)
      {

          /** @var CustomerSetup $customerSetup */
          $customerSetup = $this->customerSetupFactory->create(['setup' => $setup]);

          $customerEntity = $customerSetup->getEavConfig()->getEntityType('customer');
          $attributeSetId = $customerEntity->getDefaultAttributeSetId();

          /** @var $attributeSet AttributeSet */
          $attributeSet = $this->attributeSetFactory->create();
          $attributeGroupId = $attributeSet->getDefaultGroupId($attributeSetId);
          /**
           * customer registration form default field mobile number
           */
          $customerSetup->addAttribute(Customer::ENTITY, 'custom_field', [
              'type' => 'varchar',
              'label' => 'Custom Field',
              'input' => 'text',
              'required' => true,
              'visible' => true,
              'user_defined' => true,
              'sort_order' => 1000,
              'position' => 1000,
              'system' => 0,
          ]);
          //add attribute to attribute set
          $attribute = $customerSetup->getEavConfig()->getAttribute(Customer::ENTITY, 'mobile_number')
              ->addData([
                  'attribute_set_id' => $attributeSetId,
                  'attribute_group_id' => $attributeGroupId,
                  'used_in_forms' => ['adminhtml_customer', 'customer_account_create'],
              ]);

          $attribute->save();


      }
  }

หลังจากนั้นเรียกใช้คำสั่งด้านล่าง:

php bin/magento setup:upgrade
php bin/magento setup:static-content:deploy
php bin/magento cache:clean

คุณจะเห็นการยื่นแบบกำหนดเองของคุณในแบบฟอร์มการลงทะเบียน

แจ้งให้เราทราบหากคุณมีปัญหา


4
ตารางใดบันทึกข้อมูล
Devidas

7

คุณต้องสร้างโมดูลและนี่คือinstallData.php:

namespace Barcode\Unique\Setup;

use Magento\Framework\Setup\InstallDataInterface;
use Magento\Framework\Setup\ModuleContextInterface;
use Magento\Framework\Setup\ModuleDataSetupInterface;

class InstallData implements InstallDataInterface
{
    /**
     * Customer setup factory
     *
     * @var \Magento\Customer\Setup\CustomerSetupFactory
     */
    private $customerSetupFactory;
    /**
     * Init
     *
     * @param \Magento\Customer\Setup\CustomerSetupFactory $customerSetupFactory
     */
    public function __construct(\Magento\Customer\Setup\CustomerSetupFactory $customerSetupFactory)
    {
        $this->customerSetupFactory = $customerSetupFactory;
    }
    /**
     * Installs DB schema for a module
     *
     * @param ModuleDataSetupInterface $setup
     * @param ModuleContextInterface $context
     * @return void
     */
    public function install(ModuleDataSetupInterface $setup, ModuleContextInterface $context)
    {

        $installer = $setup;
        $installer->startSetup();

        $customerSetup = $this->customerSetupFactory->create(['setup' => $setup]);
        $entityTypeId = $customerSetup->getEntityTypeId(\Magento\Customer\Model\Customer::ENTITY);

        $customerSetup->removeAttribute(\Magento\Customer\Model\Customer::ENTITY, "barcode_unique");

        $customerSetup->addAttribute(\Magento\Customer\Model\Customer::ENTITY, "barcode_unique",  array(
            "type"     => "varchar",
            "backend"  => "",
            "label"    => "Barcode",
            "input"    => "text",
            "source"   => "",
            "visible"  => true,
            "required" => false,
            "default" => "",
            "frontend" => "",
            "unique"     => false,
            "note"       => ""

        ));

        $barcode_unique   = $customerSetup->getAttribute(\Magento\Customer\Model\Customer::ENTITY, "barcode_unique");

        $barcode_unique = $customerSetup->getEavConfig()->getAttribute(\Magento\Customer\Model\Customer::ENTITY, 'barcode_unique');

      $used_in_forms[]="adminhtml_customer";
        $used_in_forms[]="checkout_register";
        $used_in_forms[]="customer_account_create";
        $used_in_forms[]="customer_account_edit";
        $used_in_forms[]="adminhtml_checkout";

        $barcode_unique->setData("used_in_forms", $used_in_forms)
            ->setData("is_used_for_customer_segment", true)
            ->setData("is_system", 0)
            ->setData("is_user_defined", 1)
            ->setData("is_visible", 1)
            ->setData("sort_order", 1002);

        $barcode_unique->save();

        $installer->endSetup();
    }
}

สิ่งนี้จะสร้างฟิลด์และคุณสามารถโทรในไฟล์ phtml (เช่น: เพิ่มเติมinfocustomer.phtml)

คุณสามารถช่วยได้จาก 2 URL เหล่านี้: IBNABและSASHAS

ฉันหวังว่ามันจะช่วยคุณ


0

คุณสามารถดูลิงค์ด้านล่างเพื่อสร้างฟิลด์ที่กำหนดเองในหน้าลงทะเบียนใน magento2-

https://github.com/jainmegha5395/custom-fields

โมดูลที่กำหนดเองนี้จะเพิ่มฟิลด์และแอตทริบิวต์ที่กำหนดเองในแบบฟอร์มการลงทะเบียน คุณลักษณะนี้จะแสดงในการเพิ่มหรือแก้ไขแบบฟอร์มลูกค้าใน Magento 2 Admin


0

คุณสามารถให้ Magento 2 ถามที่อยู่แบบเต็มในการสร้างบัญชีได้โดยตั้งค่า show_address_fields เป็นจริงในบล็อกการลงทะเบียน - จากนั้นจะถามด้วย (นอกเหนือจากรายการอื่น) ของ บริษัท

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.