La couleur d'arrière-plan ou de police en HTML est rouge
P粉038161873
P粉038161873 2023-09-03 09:18:19
0
1
789
<p>J'ai le code suivant pour envoyer des notifications par e-mail aux destinataires et cela fonctionne très bien. Les données sources proviennent d'une requête SQL Server, que j'appelle temporairement la table "#Temp_Warning". Si la valeur de T.FORMATTED_ENTRY est inférieure à 10, mon destinataire souhaite que la valeur soit surlignée en rouge dans l'e-mail. J'ai beaucoup essayé, mais les valeurs inférieures à 10 affichent de manière inattendue l'intégralité du code<code>"span style="background-color :red;">5</span"</code> Au lieu du chiffre 5 en rouge. </p> <p>Cela fait partie du code d'une procédure stockée SQL Server</p> <pre class="brush:sql;toolbar:false;">IF (SELECT COUNT(*) FROM #Temp_Warning) > COMMENCER --Formater le contenu des e-mails en HTML DÉCLARE @tableHTML NVARCHAR(MAX); FIXER @tableHTML = N'<tr>' + N'<td><b>Nom du test</b></td>' + N'<td><b>Résultat formaté</td>' + N'&Lt ;/tr> ;' + CASTING(( SÉLECTIONNER td = T.REPORTED_NAME,'', td = CAS QUAND T.FORMATTED_ENTRY < 10 ALORS N'<span style="background-color:red;">' + T.FORMATTED_ENTRY + N'</span>' ELSE T.FORMATTED_ENTRY END, '' DE #Temp_Warning T COMMANDE PAR T.REPORTED_NAME POUR CHEMIN XML('tr'), TYPE ) COMME NVARCHAR(MAX)) + FIN </pre></p>
P粉038161873
P粉038161873

répondre à tous(1)
P粉550323338

Veuillez essayer les solutions suivantes.

Il utilise la fonctionnalité SQL Server XQuery.

De plus, il utilise CSS pour styliser le XHTML de sortie.

SQL

-- DDL and sample data population, start
DECLARE @tbl TABLE (test VARCHAR(100) PRIMARY KEY, result INT);
INSERT @tbl (test, result) VALUES
('Bu', 57),
('Po', 5),
('Zu', 9);
-- DDL and sample data population, end

DECLARE @xhtmlBody XML
   , @body NVARCHAR(MAX)
   , @tableCaption VARCHAR(30) = 'Tests results report';

SET @xhtmlBody = (SELECT (
SELECT * FROM @tbl FOR XML PATH('row'), TYPE, ROOT('root'))
.query('<html><head>
            <meta charset="utf-8"/>
            (: including embedded CSS styling :)
            <style>
            table <![CDATA[ {border-collapse: collapse;  width: 300px;} ]]>
            th <![CDATA[ {background-color: #4CAF50; color: white;} ]]>
            th, td <![CDATA[ { text-align: left; padding: 8px;} ]]>
            tr:nth-child(even) <![CDATA[ {background-color: #f2f2f2;} ]]>
            td:nth-child(2)  {text-align: center;} 
            #red <![CDATA[ {background-color: red;} ]]>
         </style>
         </head>
         <body>
<table border="1">
   <caption><h2>{sql:variable("@tableCaption")}</h2></caption>
   <thead>
      <tr>
        <th>Test Name</th>
        <th>Formatted result</th>
      </tr>
   </thead>
   <tbody>
{
    for $row in /root/row
    return <tr>
            <td>{data($row/test)}</td>
            <td>
            {if (($row/result/text())[1] lt 10) then attribute id {"red"} else ()}
            {data($row/result)}            
         </td>
        </tr>
}
</tbody></table></body></html>'));

SELECT @xhtmlBody;
SET @body = TRY_CAST(@xhtmlBody AS NVARCHAR(MAX));

Sortie XHTML

<html>
  <head>
    <meta charset="utf-8" />
    <style>
            table  {border-collapse: collapse;  width: 300px;} 
            th  {background-color: #4CAF50; color: white;} 
            th, td  { text-align: left; padding: 8px;} 
            tr:nth-child(even)  {background-color: #f2f2f2;} 
            td:nth-child(2)  {text-align: center;} 
            #red  {background-color: red;} 
         </style>
  </head>
  <body>
    <table border="1">
      <caption>
        <h2>Tests results report</h2>
      </caption>
      <thead>
        <tr>
          <th>Test Name</th>
          <th>Formatted result</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td>Bu</td>
          <td>57</td>
        </tr>
        <tr>
          <td>Po</td>
          <td id="red">5</td>
        </tr>
        <tr>
          <td>Zu</td>
          <td id="red">9</td>
        </tr>
      </tbody>
    </table>
  </body>
</html>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal