Cú pháp cơ bản của php

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 27
0, 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 27
0

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 27
1

$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
2

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 27
3

$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
4

$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
5

$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
6

$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
7

$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
8

Đầ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 27
9




    
    A Simple PHP File


    

80

Vì 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


    

85

Mộ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ày

Ghi 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


    

89

Kể 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 đơn

Ví 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


    

8

Trong ngữ cảnh lớp, có thể tạo một đối tượng mới bằng

95 và
96

Khi 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

91

Ví dụ trên sẽ xuất ra

9

Có 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

96

Ví dụ trên sẽ xuất ra

9

Có 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

97

Ví 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

10

Ví 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

14

Ví 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

17

Ví dụ trên sẽ xuất ra

1

Quy 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ớp

Ví 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 27
20

$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
21

$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
22

$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
23

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 27
24

$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
25

Đầ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 27
2

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 27
24

$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
27

Đầ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 27
1

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 27
28

$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
29

$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
10

$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
11

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 27
6

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 27
0 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 27
13, 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 27
14. Đ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 27
15

$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
16

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 27
18

Ví 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ượng

Ví 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 27
60

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 27
61. 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 27
62 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 27
62 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 27
64

$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
65

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ệ

Chủ Đề