اذهب إلى المحتوى

السؤال

نشر

أحاول أن أضع كود HTML أقوم بجلبة بإستخدام Ajax لكني عند عرض هذا الكود يظهر في شكل نص وليس كود يتم تطبيقه في المتصغح، هنا كود Ajax الذي أستخدمه:

$.ajax({
   url: 'https://example.com/posts/,
   dataType: "json",
   success: function(data) {
      this.setState({
           posts: data.posts
      })
   }.bind(this)
});

ثم أقوم بعرض كود HTML بالشكل التالي:

<div>
  {this.state.posts}
</div>

في النهاية أحصل على الكود الصحيح، لكن المشكلة تكمن في طريقة عرضه في المتصفح حيث يظهر كنص وليس كود كما وضحت سابقًا.

Recommended Posts

  • 0
نشر

سبب المشكلة هو أنه لا يتم تفسير النص ك شيفرة HTML ولا يتم عمل render لها لذلك يجب تطبيق المنطق التالي:

  render() {
    return (
      <div dangerouslySetInnerHTML={{ __html: this.state.posts }} />
    );
  }

أو

  render() {
    return (
      <div dangerouslySetInnerHTML={{ __html: this.htmlDecode(this.state.posts) }} />
    );
  }

 

  • 0
نشر

في أغلب الأحيان سوف تحتاج تنظيف ال html  أو تعديله قليلا قبل حقنه لذا من المنصوح به أن تعين دالة خارجية لتتكفل بالأمر 

const injectHtml = __html => ({
  __html
});

const Component = ({ html }) => (
  <div>
    <div dangerouslySetInnerHTML={injectHtml(html)} />
  </div>
);

اذا كان لديك محتةى في ال html مثل هذا 

&lt;em&gt;نص ما هنا:&lt;/em&gt;

يمكنك معالجته باستخدام unescape من مكتبة lodash

import _ from 'lodash';

const injectHtml = html => ({
  __html: _.unescape(html),
});


const Component = ({ html }) => (
  <div>
    <div dangerouslySetInnerHTML={injectHtml(html)} />
  </div>
);

 

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...