Unlimited Plugins, WordPress themes, videos & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Code
  2. Yii

यी2(Yii2) के साथ प्रोग्रामिंग: वोटिंग, टिप्पणियाँ और साझाकरण के साथ बिल्डिंग कम्यूनिटी

by
Difficulty:IntermediateLength:MediumLanguages:
This post is part of a series called How to Program With Yii2.
Programming With Yii2: Building a RESTful API
Programming With Yii: Generating Documentation

Hindi (हिंदी) translation by Shubham Sharma (you can also view the original English article)

Final product image
What You'll Be Creating

इस यी2(Yii2) श्रृंखला के साथ प्रोग्रामिंग में, मैं पाठकों को PHP के लिए यी2(Yii2) फ्रेमवर्क के उपयोग में मार्गदर्शन करता हूं। आपको Yii फ्रेमवर्क के बारे में भी दिलचस्पी हो सकती है, जो Yii के लाभों की समीक्षा करती है और इसमें Yii 2.x में नया क्या है, इसका अवलोकन शामिल है।

परिचय

आज के ट्यूटोरियल में, मैं आपको यह दिखाने वाला हूँ कि यी(Yii) को आसानी से एक साइट की नकल, टिप्पणियों, और साझाकरण के साथ रेडडिट जैसी नकल करने मे कैसे उपयोग करें।

हाल ही में, मैं महान Yii उन्नत टेम्पलेट का अपना व्यक्तिगत विस्तार बनाने पर काम कर रहा हूं। टेम्पलेट अंतर्निहित उपयोगकर्ता पंजीकरण और प्रमाणीकरण और फ्रंट-एंड और प्रशासनिक वेबसाइट्स के लिए एकाधिक साइट प्रदान करता है।

मैंने इस मंच के शुरुआती संस्करण पर अपने नवीनतम ट्विटर एपीआई एपिसोड का निर्माण किया, उपयोगकर्ताओं की ओर से मित्रों के अनुसरण में और हमारे अनुयायियों का विश्लेषण करने के लिए। साइट मैं उन में वर्णित है, Twixxr, मेरे यी(Yii) अनुकूलन कार्य की नींव रूप है।

तो वोटिंग, टिप्पणियां और साझा करना जैसे मुख्य कार्यप्रणाली को जोड़ना इतना समझ में आता है।जैसा कि आप इन प्रकार के सुविधाओं के साथ अपने यी(Yii) कोडबेस(codebase) का विस्तार करते हैं, नई साइट्स का निर्माण तेजी से, आसान और तेजी से शक्तिशाली हो जाता है।

प्रारंभ करना

मैं तीन यी2 प्लगइन्स(Yii2 plugins) के उपयोग के माध्यम से आपको चलने जा रहा हूं:

वे इसे अपेक्षाकृत तेज और आसान बनाने के लिए Yii2 पर एक शक्तिशाली सामाजिक समुदाय बनाते हैं।

मैंने item नामक एक मॉडल बनाया है जो एक ऐसे ऑब्जेक्ट का प्रतिनिधित्व करता है जिसे आप चाहते हैं कि उपयोगकर्ता वोट करें, टिप्पणी करें और साझा करें।

सच कहूँ तो, मेरे मंच में इन सुविधाओं के साथ आइटम पृष्ठों को बनाने के बाद, मैं यी(Yii) के साथ पहले से कहीं अधिक प्रभावित हुआ ... अधिक समय तक मेरी स्टार्टअप सीरीज़ बनाने की तुलना में प्रभावित हुआ। आप इस ढांचे के साथ इतना कुछ कर सकते हैं।

चलो और जाने

एक्सटेंशन स्थापित करना

सबसे पहले, चलो एक साथ सभी तीन एक्सटेंशन composer.json को जोड़ते हैं:

तब चलाऐ composer update ।

वोटिंग जोड़ना

व्लादिमीर बबिन चिलिएक है, और मुझे बहुत पसंद है जैसे वे और दूसरों ने इस प्लगइन को बनाने के लिए सहयोग किया है। आप चाहते हैं कि सभी बुनियादी सुविधाओं को शामिल किया गया है, और आप आसानी से इसे अनुकूलित कर सकते हैं, विशेष रूप से दृश्य ओवरराइड द्वारा। उनके पास महान दस्तावेज हैं और इसे अच्छी तरह से अद्यतन भी रखें।

यहां प्लगइन की डिफ़ॉल्ट विशेषताओं का एक उपयोगी एनिमेटेड जीआईफ़ है जो वे गीथहब पर होस्ट करते हैं। मैंने नीचे एक स्थिर छवि पोस्ट की है (एनवाटो टट्स+ हमारे ट्यूटोरियल में जीफ का समर्थन नहीं करता है)।

Programming With Yii - Voting Plugin Default Example

बेशक, मैंने इस दृश्य को अनुकूलित करने और वोटों को खत्म करने का निर्णय लिया, और यह काफी आसान था।

कॉन्फ़िगरेशन

इसके बाद, हम /active/config/main.php में मतदान प्लगइन जोड़ते हैं ताकि यह बूटस्ट्रैप में हर जगह लोड हो और हमारे एप्लिकेशन के लिए कॉन्फ़िगर किया जा सके:

आप देख सकते हैं कि मैंने अतिथि मतदान को बंद कर दिया है ताकि लोगों को आइटम पर वोट करने के लिए साइन अप करना होगा।

डेटाबेस एकीकरण

इसके बाद, आपको तालिकाओं को बनाने के लिए डेटाबेस प्रवास चलाया जाना है जो वोटों को ट्रैक करते हैं।

अपने उत्पाद सर्वर को स्थापित करते समय इस माइग्रेशन को चलाने के लिए याद रखना महत्वपूर्ण है! यह भूलना काफी आसान है।

वोटिंग विजेट प्रदर्शित करना

मेरा आइटम मॉडल एक संग्रह मॉडल का हिस्सा है जिसे विषय कहा जाता है, ताकि आप मेरे वोटिंग विजेट के लिए आंशिक दृश्य खोज सकें /views/topic/_item.php:

विषय सूचकांक एक ग्रिड प्रदर्शित करता है जो एक पंक्ति के रूप में _item.php दिखाता है। मैं एक रेटिंग प्रदर्शित नहीं करना चाहता था, केवल सकारात्मक वोट योग, इसलिए मैंने इसे झूठा कहा।

दृश्य ओवरराइड करने के लिए, मैंने /views/vote/vote.php बनाया है:

बहुत सारे प्लगइन्स इतनी आसानी से ओवरराइड नहीं करते हैं।

मैंने वोट डाउन आइकन निकाल दिया और वोट अप आइकन को शेवरॉन में बदल दिया। यह अब जैसा दिखता है:

Programming With Yii - Voting Widget

मुझे पता है कि यह कई परतों की तरह दिखती है, लेकिन वास्तव में यह काम करने के लिए बहुत लंबा नहीं लगा था।

डिस्कस टिप्पणियां जोड़ना

इसके बाद, मैंने आगामी साइट, ActiveTogether.org, के लिए एक डिस्कस साइट बनाई, जो आपके द्वारा इस सुविधा को पढ़ने के समय तक इन सुविधाओं को देखने के लिए उपलब्ध होगी। इस प्रकार, डिस्कस साइट शॉर्ट-नाम 'सक्रिय-एक साथ' है।

इससे पहले कि मैं कार्तिक के सामाजिक विस्तार (नीचे चर्चा की गई) को एकीकृत करने से पहले 2एमीगोस विजेट का उपयोग करना शुरू किया, जो भी डिस्कस टिप्पणियों की पेशकश करता है।

प्रत्येक टिप्पणी बोर्ड के लिए एक अद्वितीय पहचानकर्ता बनाना

जब भी कोई नया आइटम बनाया जाता है, तो Item::beforeSave() कार्रवाई डिस्कस के लिए एक अद्वितीय पहचानकर्ता भी टिप्पणी को लिंक करने के लिए बनाता है। आप किसी पृष्ठ के यूआरएल पर भरोसा भी कर सकते हैं, लेकिन यह सामान्यतः अधिक अनुमान लगाया जा सकता है।

दूसरे शब्दों में, डिस्कस प्रत्येक आइटम के लिए अलग से सभी टिप्पणियों को अलग करता है, और इससे प्रत्येक आइटम की टिप्पणी बोर्ड को मदद मिलती है।

टिप्पणियां प्रदर्शित करना

इसके बाद, टिप्पणी बोर्ड आसानी से आइटम दृश्य के नीचे प्रदर्शित होता है /active/views/Item.php में:

टिप्पणियों के लिए डिस्कस प्रदान करने के लिए विजेट को shortname और identifier की आवश्यकता है या नहीं।

यहां टिप्पणी बोर्ड की तरह दिखने वाला एक उदाहरण है:

Programming With Yii - Item Page with voting sharing and comments board

सूचकांक दृश्य टिप्पणी टिप्पणी के साथ

2अमीगोस ने टिप्पणी की गणना दिखाने के लिए डिस्कस जावास्क्रिप्ट लाइब्रेरी का भी लाभ उठाया है। लेकिन ऐसा होने के लिए कुछ टुकड़े एक साथ रखे हैं।

सबसे पहले, मैंने एक आइटम की टिप्पणी की गिनती के लिए एक जेक्वेरी स्क्रिप्ट बनाया। जब पृष्ठ पर बहुत सारी वस्तुएं होती हैं, तो आपको इसे रीसेट के साथ अनुरोध करना reset: true;:

फिर मैंने .js फ़ाइल को लोड करने के लिए TopicAsset.php फ़ाइल बनाई है:

उसके बाद, /active/views/Topic.php फ़ाइल TopicAsset बंडल पंजीकृत करता है:

अगला, each_item.php आंशिक में एक टिप्पणी की संख्या शामिल है:

और _social आंशिक प्रत्येक Item-> identifier का उपयोग करके इसे इस तरह दिखता है:

डिस्कस के लिए टिप्पणी की गणना के साथ तत्वों को अपडेट करने का पता लगाने के लिए, प्रत्येक लिंक #disqus_thread के साथ समाप्त होना चाहिए।

वह पृष्ठ है जो उस पृष्ठ की तरह दिखता है। प्रत्येक आइटम में अपनी पहचानकर्ता को संदर्भित करके भरी हुई टिप्पणी की गिनती है:

Programming With Yii - Index page of with voting and social comments and sharing

चलिए उन सामाजिक साझाकरण बटनों पर चलते हैं जो आप देख रहे थे।

सामाजिक साझाकरण जोड़ना

कार्तिक ने अपने सामाजिक विजेट के साथ एक महान काम किया है जिसमें ट्विटर, डिस्कस और फेसबुक जैसी कई सामाजिक कंपनियों के संबंध में बुनियादी विन्यास का निर्माण किया गया है। अभी के लिए, मैं केवल फेसबुक शेयर बटन का उपयोग कर रहा हूं। ट्विटर शेयर बटन में बहुत अच्छा सौंदर्यशास्त्र नहीं है, इसलिए मैंने इसे एक HTML वेब ऐन्टेंट लिंक के साथ बदल दिया।

/active / views /topic/_social.php में टिप्पणियों की गिनती के बगल में बटनों की जोड़ी के लिए मेरा कोड है:

सरल लगता है, सिवाय इसके कि खड़ी संरेखित फेसबुक के विजेट को कुछ सीएसएस समायोजन की आवश्यकता है। /active/views/topic/_grid.php में, मैंने यह समायोजन रखा है:

इसे अन्य सीएसएस फ़ाइलों के लोड होने के बाद आना होगा।

और, site.css फ़ाइल में, मैंने इसे मैं सटीक रूप से देखने के लिए रखा था:

रैपिंग अप

ईमानदारी से, मैं इतनी उत्साहित हूं कि ये कितनी आसानी से यी का उपयोग करना था और मूल रूप से एक मिनी सामाजिक क्लोन बनाना।ये महान फ्रेमवर्क के लिए महान प्लग-इन हैं, और आम तौर पर यी(Yii) के डेवलपर्स और प्लगइन डेवलपर्स के इसके समुदाय डेवलपर्स के सवाल और मुद्दों के साथ GitHub पर प्रतिक्रियाशील हैं।

मुझे आशा है कि आप ActiveTogether को देखने के लिए उत्सुक हैं और अपने लिए यह रूपरेखा देखेंगे।

यदि आपके पास कोई प्रश्न या सुझाव हैं, तो कृपया उन्हें टिप्पणियों में पोस्ट करें। अगर आप मेरे भविष्य के एन्वाटो ट्यूट्स+ ट्यूटोरियल और अन्य सीरीज पर बने रहना चाहते हैं, तो कृपया मेरे प्रशिक्षक पृष्ठ पर जाएं या @lookahead_io का पालन करें। निश्चित रूप से मेरी स्टार्टअप श्रृंखला और मीटिंग प्लानर देखें।

सम्बंधित लिंक्स

Advertisement
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.