Вопрос

Я пишу программу для добавления некоторого кода в html-файлы

Я собирался использовать серию indexof и циклов, чтобы найти то, что по сути является ""X (где X - это место, которое я ищу)

Мне пришло в голову, что, возможно, есть более красноречивый способ сделать это

у кого-нибудь есть какие-либо предложения.

как это выглядит в настоящее время

<body onLoad="JavaScript:top.document.title='Abraham L Barbrow'; if (self == parent) document.getElementById('divFrameset').style.display='block';">

как это должно выглядеть, когда я закончу


<body onLoad="JavaScript:top.document.title='Abraham L Barbrow'; if (self == parent) document.getElementById('divFrameset').style.display='block';">
<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script>
<script type="text/javascript">
try {
var pageTracker = _gat._getTracker("UA-9xxxxxx-1");
pageTracker._trackPageview();
} catch(err) {}</script>
Это было полезно?

Решение

Я не уверен, что понимаю тебя, но ты это серьезно?

// Given an HTML document in "htmlDocument", and new content in "newContent"
string newHtmlDocument = htmlDocument.Replace("</body>", newContent+"</body>");

И, наверное, очевидно, что я не знаю c #...Вероятно, вы хотели бы сделать тег "body" нечувствительным к регистру с помощью регулярных выражений.

Другие советы

Я бы рекомендовал использовать HtmlAgilityPack HtmlAgilityPack чтобы разобрать html-код в DOM и работать с ним.

public string AddImageLink(string emailBody,string imagePath)
{
    try
    {
    HtmlDocument doc = new HtmlDocument();
    doc.LoadHtml(emailBody);

    HtmlNode node = doc.DocumentNode.SelectSingleNode("//body");

    // get body using xpath query ("//body")
    // create the new node ..

    HtmlNodeCollection LinkNode = new HtmlNodeCollection(node);
    //

    HtmlNode linkNode = new HtmlNode(HtmlNodeType.Element,doc,0);
    linkNode.Name = "A";
    linkNode.Attributes.Add("href","www.splash-solutions.co.uk");


    HtmlNode imgNode = new HtmlNode(HtmlNodeType.Element,doc,1);
    imgNode.Name = "img";
    imgNode.Attributes.Add("src",imagePath);

    //appending the linknode with image node
    linkNode.AppendChild(imgNode);

    LinkNode.Append(linkNode);

    //appending LinkNode to the body of the html
    node.AppendChildren(LinkNode);


    StringWriter writer = new StringWriter();
    doc.Save(writer);
    emailBody = writer.ToString();
    return emailBody;
}

Если HTML-файлы являются допустимым XHTML, вы всегда можете использовать класс XmlDocument для его интерпретации.Затем вы могли бы легко найти Тело элемент и добавьте к нему дочерний элемент.Это поместило бы элемент прямо перед закрытием </body> пометка.

Возможно, вы захотите рассмотреть возможность использования пакета Html Agility Pack

http://www.codeplex.com/htmlagilitypack

Я не уверен, является ли пример содержимого, которое вы хотите добавить после тега, правильным или нет, но если это так, я вижу две проблемы:

  1. Код Google Analytics должен быть добавлен непосредственно перед конечная метка, а не открывающий тег.Это гарантирует, что вам не придется ждать его загрузки перед загрузкой вашего собственного кода.
  2. Если вы добавляете какой-то другой javascript, почему бы не добавить его во внешний файл и не выполнить вместо него onload?

Надеюсь, это хоть как-то поможет :)

Это то, что у меня есть

не стесняйтесь вносить предложения

 private void button1_Click(object sender, EventArgs e)
        {
            OpenFileDialog OFD = new OpenFileDialog();
            OFD.Multiselect = true;
            OFD.Filter = "HTML Files (*.htm*)|*.HTM*|" +
          "All files (*.*)|*.*";

            if (OFD.ShowDialog() == DialogResult.OK)
            {
                foreach (string s in OFD.FileNames)
                {
                    Console.WriteLine(s);
                    AddAnalytics(s);
                }
                MessageBox.Show("done!");
            }
        }
        private void AddAnalytics(string filename)
        {

            string Htmlcode = "";
            using (StreamReader sr = new StreamReader(filename))
            {
                Htmlcode = sr.ReadToEnd();
            }
            if (!Htmlcode.Contains(textBox1.Text))
            {
                Htmlcode = Htmlcode.Replace("</body>", CreateCode(textBox1.Text) + "</body>");

                using (StreamWriter sw = new StreamWriter(filename))
                {
                    sw.Write(Htmlcode);
                }
            }
        }

        private string CreateCode(string Number)
        {
            StringBuilder sb = new StringBuilder();
            sb.AppendLine();
            sb.AppendLine("<script type=\"text/javascript\">");
            sb.AppendLine("var gaJsHost = ((\"https:\" == document.location.protocol) ? \"https://ssl.\" : \"http://www.\");");
            sb.AppendLine("document.write(unescape(\"%3Cscript src='\" + gaJsHost + \"google-analytics.com/ga.js' ");
            sb.AppendLine("<//script>");
            sb.AppendLine("<script type=/\"text//javascript/\">");
            sb.AppendLine("try {");
            sb.AppendLine(string.Format("var pageTracker = _gat._getTracker(/\"{0}/\");", Number));///"UA-9909000-1"
            sb.AppendLine("pageTracker._trackPageview();");
            sb.AppendLine("} catch(err) {}<//script>");
            sb.AppendLine();
            return sb.ToString();
        }
    }
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top