Dấu phân cách PHP Trong ví dụ sau chỉ đơn giản là yêu cầu công cụ PHP xử lý khối mã kèm theo dưới dạng mã PHP, thay vì HTML đơn giản
Mỗi câu lệnh PHP kết thúc bằng dấu chấm phẩy “;”
2. Nhúng PHP vào HTML
Các tệp PHP là các tệp văn bản đơn giản với phần đuôi mở rộng. php
Bên trong tệp PHP, bạn có thể viết HTML giống như bạn đang làm trong các trang HTML thông thường cũng như nhúng mã PHP để thực thi phía máy chủ
A Simple PHP File
Ví dụ về cách bạn có thể nhúng mã PHP trong HTML để tạo các trang web động có định dạng tốt
Nếu bạn xem mã nguồn của trang web trong trình duyệt của mình, sự khác biệt duy nhất bạn sẽ thấy là mã PHP đã được thay thế bằng đầu ra 'Xin chào, thế giới'
Chuyện gì đã xảy ra ở đây?
Khi bạn chạy đoạn mã này, PHP Engine đã thực hiện các hướng dẫn giữa các thẻ
Khi hoàn tất, máy chủ web sẽ gửi đầu ra cuối cùng quay lại trình duyệt của bạn hoàn toàn bằng mã HTML
3. Nhận xét PHP
Một bình luận đơn giản chỉ là đoạn văn bản bị loại bỏ bởi PHP Engine. Mục đích của các bình luận là giải thích đoạn mã đang làm cái gì
Có mã nhận xét sẽ giúp các thành viên lập trình khác [hoặc chính bạn trong tương lai khi bạn quay lại chỉnh sửa mã nguồn đã chỉnh sửa] để hiểu đoạn mã này đang cố gắng làm gì với PHP
PHP hỗ trợ các dòng đơn cũng như các bình luận nhiều dòng. Để viết bình luận, một dòng ta bắt đầu với 2 dấu gạch chéo “//” hoặc ký hiệu #. Ví dụ
Tuy nhiên, để viết bình luận nhiều dòng, hãy bắt đầu bình luận bằng dấu gạch chéo và theo sau là dấu hoa thị /* rồi kết thúc bình luận bằng dấu hoa thị theo sau là dấu gạch chéo */, ví dụ như sau
4. Viết Hoa, viết thường trong PHP
Tên biến trong PHP là trường hợp phân biệt Hoa thường [Phân biệt chữ hoa chữ thường]. Kết quả là các biến $color, $Color và $COLOR được coi là ba biến khác nhau
Nếu bạn cố chạy đoạn mã ví dụ trên, nó sẽ chỉ hiển thị giá trị của biến $color và tạo cảnh báo “Biến không xác định” cho biến $Color và $COLOR
Tuy nhiên, các từ khóa, chức năng và tên lớp không phân biệt chữ hoa chữ thường. Kết quả được gọi là gettype[] hoặc GETTYPE[] sẽ tạo ra kết quả tương tự
Nếu bạn cố chạy ví dụ trên, cả hai hàm gettype[] và GETTYPE[] đều cho cùng một đầu ra, đó là. sợi dây
Các định nghĩa lớp cơ bản bắt đầu bằng từ khóa
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 270, theo sau là tên lớp, tiếp theo là một cặp dấu ngoặc nhọn bao quanh các định nghĩa về thuộc tính và phương thức thuộc về lớp
Tên lớp có thể là bất kỳ nhãn hợp lệ nào, miễn là nó không phải là từ dành riêng cho PHP. Tên lớp hợp lệ bắt đầu bằng một chữ cái hoặc dấu gạch dưới, theo sau là bất kỳ số lượng chữ cái, số hoặc dấu gạch dưới nào. Là một biểu thức chính quy, nó sẽ được thể hiện như vậy.
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 270
Một lớp có thể chứa các hằng, biến [được gọi là "thuộc tính"] và hàm [được gọi là "phương thức"] của riêng nó
Ví dụ #1 Định nghĩa lớp đơn giản
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 271
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 272
Biến giả $this khả dụng khi một phương thức được gọi từ bên trong ngữ cảnh đối tượng. $đây là giá trị của đối tượng gọi
Cảnh báo
Gọi một phương thức không tĩnh sẽ gây ra Lỗi tĩnh. Trước PHP 8. 0. 0, điều này sẽ tạo ra một thông báo không dùng nữa và $this sẽ không được xác định
Ví dụ #2 Một số ví dụ về biến giả $this
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 273
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 274
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 275
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 276
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 277
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 278
Đầu ra của ví dụ trên trong PHP 7
A Simple PHP File
5Đầu ra của ví dụ trên trong PHP 8
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 27
lớp chỉ đọc
Kể từ PHP 8. 2. 0, một lớp có thể được đánh dấu bằng công cụ sửa đổi chỉ đọc. Đánh dấu một lớp là chỉ đọc sẽ thêm công cụ sửa đổi chỉ đọc vào mọi thuộc tính đã khai báo và ngăn việc tạo các thuộc tính động. Hơn nữa, không thể thêm hỗ trợ cho chúng bằng cách sử dụng thuộc tính AllowDynamicProperties. Cố gắng làm như vậy sẽ gây ra lỗi thời gian biên dịch
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 279
A Simple PHP File
80Vì không thể đánh dấu thuộc tính untyped, cũng như tĩnh bằng công cụ sửa đổi
A Simple PHP File
81, nên các lớp chỉ đọc cũng không thể khai báo chúng
A Simple PHP File
82
A Simple PHP File
83
A Simple PHP File
84
A Simple PHP File
85Một lớp chỉ đọc có thể được mở rộng nếu và chỉ khi lớp con cũng là một lớp chỉ đọc
Mới
Để tạo một thể hiện của một lớp, phải sử dụng từ khóa
A Simple PHP File
86. Một đối tượng sẽ luôn được tạo trừ khi đối tượng đó có một hàm tạo được xác định sẽ đưa ra một ngoại lệ do lỗi. Các lớp nên được xác định trước khi khởi tạo [và trong một số trường hợp, đây là một yêu cầu]Nếu một chuỗi chứa tên của một lớp được sử dụng với
A Simple PHP File
86, một phiên bản mới của lớp đó sẽ được tạo. Nếu lớp nằm trong một không gian tên, tên đầy đủ của nó phải được sử dụng khi thực hiện việc nàyGhi chú
Nếu không có đối số nào được chuyển đến hàm tạo của lớp, dấu ngoặc đơn sau tên lớp có thể được bỏ qua
Ví dụ #3 Tạo một thể hiện
A Simple PHP File
88
A Simple PHP File
89Kể từ PHP 8. 0. 0, sử dụng
A Simple PHP File
86 với các biểu thức tùy ý được hỗ trợ. Điều này cho phép khởi tạo phức tạp hơn nếu biểu thức tạo ra một chuỗi. Các biểu thức phải được bao bọc trong dấu ngoặc đơnVí dụ #4 Tạo một thể hiện bằng một biểu thức tùy ý
Trong ví dụ đã cho, chúng tôi hiển thị nhiều ví dụ về biểu thức tùy ý hợp lệ tạo ra tên lớp. Phần này hiển thị lời gọi hàm, nối chuỗi và hằng số
91
92
93
94Đầu ra của ví dụ trên trong PHP 8
A Simple PHP File
8Trong ngữ cảnh lớp, có thể tạo một đối tượng mới bằng
95 và
96Khi gán một thể hiện đã được tạo của một lớp cho một biến mới, biến mới sẽ truy cập vào thể hiện giống như đối tượng đã được gán. Hành vi này giống nhau khi chuyển các thể hiện cho một hàm. Một bản sao của một đối tượng đã được tạo có thể được tạo bằng cách sao chép nó
Ví dụ #5 Gán đối tượng
A Simple PHP File
88
98
99
90
91Ví dụ trên sẽ xuất ra
9Có thể tạo các thể hiện của một đối tượng theo một số cách
Ví dụ #6 Tạo đối tượng mới
92
93
94
95
96Ví dụ trên sẽ xuất ra
9Có thể truy cập một thành viên của một đối tượng mới được tạo trong một biểu thức
Ví dụ #7 Truy cập thành viên của đối tượng mới tạo
97Ví dụ trên sẽ xuất ra một cái gì đó tương tự như
Ghi chú. Trước PHP 7. 1, các đối số không được ước tính nếu không có hàm tạo nào được xác định
Thuộc tính và phương thức
Các thuộc tính và phương thức của lớp nằm trong các "không gian tên" riêng biệt, vì vậy có thể có một thuộc tính và một phương thức có cùng tên. Việc đề cập đến cả một thuộc tính và một phương thức có cùng một ký hiệu và liệu một thuộc tính sẽ được truy cập hay một phương thức sẽ được gọi, chỉ phụ thuộc vào ngữ cảnh, i. e. việc sử dụng là truy cập biến hay gọi hàm
Ví dụ #8 Quyền truy cập tài sản so với. gọi phương thức
98
99
10Ví dụ trên sẽ xuất ra
Điều đó có nghĩa là không thể trực tiếp gọi một chức năng ẩn danh đã được gán cho một thuộc tính. Thay vào đó, thuộc tính phải được gán cho một biến trước, chẳng hạn. Có thể gọi trực tiếp một thuộc tính như vậy bằng cách đặt nó trong dấu ngoặc đơn
Ví dụ #9 Gọi một hàm ẩn danh được lưu trữ trong một thuộc tính
11
12
13
14Ví dụ trên sẽ xuất ra
mở rộng
Một lớp có thể kế thừa các hằng số, phương thức và thuộc tính của lớp khác bằng cách sử dụng từ khóa
15 trong phần khai báo lớp. Không thể mở rộng nhiều lớp; Các hằng, phương thức và thuộc tính kế thừa có thể được ghi đè bằng cách khai báo lại chúng với cùng tên được định nghĩa trong lớp cha. Tuy nhiên, nếu lớp cha đã định nghĩa một phương thức hoặc hằng số là cuối cùng, thì chúng có thể không bị ghi đè. Có thể truy cập các phương thức bị ghi đè hoặc thuộc tính tĩnh bằng cách tham chiếu chúng với cha
Ghi chú. Kể từ PHP 8. 1. 0, hằng số có thể được khai báo là cuối cùng
Ví dụ #10 Kế thừa lớp đơn giản
16
17Ví dụ trên sẽ xuất ra
1Quy tắc tương thích chữ ký
Khi ghi đè một phương thức, chữ ký của nó phải tương thích với phương thức cha. Mặt khác, một lỗi nghiêm trọng được phát ra hoặc trước PHP 8. 0. 0, một lỗi cấp độ
18 được tạo ra. Chữ ký tương thích nếu nó tôn trọng các quy tắc phương sai, làm cho tham số bắt buộc trở thành tùy chọn và nếu có bất kỳ tham số mới nào là tùy chọn. Điều này được gọi là Nguyên tắc thay thế Liskov, viết tắt là LSP. Hàm tạo và các phương thức
19 được miễn trừ khỏi các quy tắc tương thích chữ ký này và do đó sẽ không phát ra lỗi nghiêm trọng trong trường hợp chữ ký không khớpVí dụ #11 Các phương thức con tương thích
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2720
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2721
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2722
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2723
Ví dụ trên sẽ xuất ra
Các ví dụ sau đây chứng minh rằng một phương thức con loại bỏ một tham số hoặc bắt buộc một tham số tùy chọn không tương thích với phương thức cha
Ví dụ #12 Lỗi nghiêm trọng khi một phương thức con loại bỏ một tham số
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2724
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2725
Đầu ra của ví dụ trên trong PHP 8 tương tự như
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 272
Ví dụ #13 Lỗi nghiêm trọng khi một phương thức con bắt buộc tham số tùy chọn
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2724
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2727
Đầu ra của ví dụ trên trong PHP 8 tương tự như
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 271
Cảnh báo
Đổi tên tham số của phương thức trong lớp con không phải là sự không tương thích về chữ ký. Tuy nhiên, điều này không được khuyến khích vì nó sẽ dẫn đến Lỗi thời gian chạy nếu các đối số được đặt tên được sử dụng
Ví dụ #14 Lỗi khi sử dụng các tham số và đối số được đặt tên đã được đổi tên trong một lớp con
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2728
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2729
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2710
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2711
Ví dụ trên sẽ xuất ra một cái gì đó tương tự như
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 276
lớp
Từ khóa
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 270 cũng được sử dụng để phân giải tên lớp. Để có được tên đủ điều kiện của một lớp
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2713, hãy sử dụng
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2714. Điều này đặc biệt hữu ích với các lớp được đặt tên
Ví dụ #15 Độ phân giải tên lớp
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2715
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2716
Ví dụ trên sẽ xuất ra
Ghi chú
Độ phân giải tên lớp bằng cách sử dụng
91 là một phép biến đổi thời gian biên dịch. Điều đó có nghĩa là tại thời điểm chuỗi tên lớp được tạo, chưa có quá trình tự động tải nào xảy ra. Kết quả là, tên lớp được mở rộng ngay cả khi lớp không tồn tại. Không có lỗi được đưa ra trong trường hợp đóVí dụ #16 Thiếu độ phân giải tên lớp
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2718Ví dụ trên sẽ xuất ra
Kể từ PHP 8. 0. 0, hằng số
91 cũng có thể được sử dụng trên các đối tượng. Độ phân giải này xảy ra trong thời gian chạy, không phải thời gian biên dịch. Tác dụng của nó giống như gọi get_class[] trên đối tượngVí dụ #17 Độ phân giải tên đối tượng
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2760
Ví dụ trên sẽ xuất ra
Các phương thức và thuộc tính Nullsafe
Kể từ PHP 8. 0. 0, các thuộc tính và phương thức cũng có thể được truy cập bằng toán tử "nullsafe" thay thế.
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2761. Toán tử nullsafe hoạt động giống như truy cập thuộc tính hoặc phương thức như trên, ngoại trừ nếu đối tượng được hủy đăng ký là
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2762 thì
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2762 sẽ được trả về thay vì ném ngoại lệ. Nếu dereference là một phần của chuỗi, phần còn lại của chuỗi sẽ bị bỏ qua
Hiệu ứng này tương tự như gói từng quyền truy cập trong kiểm tra is_null[] trước, nhưng nhỏ gọn hơn
Ví dụ #18 Toán tử Nullsafe
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2764
$this is defined [A] Fatal error: Uncaught Error: Non-static method A::foo[] cannot be called statically in %s :27 Stack trace: #0 {main} thrown in %s on line 2765
Ghi chú
Toán tử nullsafe được sử dụng tốt nhất khi null được coi là giá trị hợp lệ và có thể được mong đợi cho thuộc tính hoặc phương thức trả về. Để chỉ ra lỗi, tốt hơn là ném ngoại lệ